Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Вывести всех однофамильцев - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задачка про IP сети, работа с массивами http://www.cyberforum.ru/cpp-beginners/thread888195.html
Помогите пожалуйста %) Задача Перед министерством страны стоит задача: объединить все IP адреса, которые есть в стране, в наименьшую возможную сеть. Для этого работники переписали все IP адреса,...
C++ Можно ли распарсить XLS файл? Всем добрый день хотел задать вопрос, можно ли распарсить XLS файл средствами C++? Заранее спасибо. http://www.cyberforum.ru/cpp-beginners/thread888183.html
переопределение методов класса в массиве C++
Всем привет. У меня появилась проблема, которую я не могу решить. Казалось бы все просто, но гугл помочь не смог, или я чего-то упорно не понимаю. У нас есть массив классов с некой функцией, пример:...
Как передать управление в блок catch после системного исключения (компилятор g++)? C++
Вот пример: не удаётся это сделать #include <windows.h> #include <stdio.h> //Эта функция- НОВЫЙ обработчик исключений LONG WINAPI f(struct _EXCEPTION_POINTERS* except_info) {...
C++ error C3861: puttext: идентификатор не найден http://www.cyberforum.ru/cpp-beginners/thread888154.html
Помогите разобраться: visualStudio 8 выдает сообщение error C3861: puttext: идентификатор не найден, хотя conio.h подключен #include <conio.h> int _tmain(int argc, _TCHAR* argv) { char *buf; ...
C++ Отображения (Разработать программу, которая хранит информацию о школьниках и их оценках за 5 экзаменов) Разработать программу, которая хранит информацию о школьниках и их оценках за 5 экзаменов в виде отображения (map). Каждый элемент отображения должен иметь следующий вид: ключ – фамилия ученика,... подробнее

Показать сообщение отдельно
o33ik
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228

Вывести всех однофамильцев - C++

02.06.2013, 16:21. Просмотров 436. Ответов 0
Метки (Все метки)

Есть массив обьектов. Надо вывести всех однофамильцев по очереди. я сделал так что береться первый елемент(первый цикл), и проверяеться со всеми остальними(второй цикл), если елемент подошел то помечаем провереным. когда мы сравним первый елемент он будет тоже "помечен" как провереный. И так дальше. А оно сначала выводит однофамильцев, а потом все остальное.
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
#include <fstream>     
#include <iostream> 
#include <string.h>
 
#define C 100
 
using namespace std; 
 
class person             
{   
protected:     
    char prizv[80];      
    char name;
    char father;
    bool anav;
public:
    person()
    {
    };
    ~person(){};
    person(const person &t)
    {
        name = t.name;
        strcpy(prizv,t.prizv);
        father = t.father;
        anav = t.anav;
    }
    void getdata()   
    {       
        cout << "\nEnter : "; 
        cin >> prizv >> name >> father;    
        anav = true;
    }     
    void showData()
    {       
        cout << "\n  Person:\t\n" << prizv << " " << name << "." << father << ".";    
        cout << endl;
    } 
    char* return_()
    {
        return prizv;
    }
    bool ret_anav()
    {
        return anav;
    }
    void make_false()
    {
        anav = false;
    };
}; 
 
void main() 
{   
    char ch;   
    person pers;
    person arr[C];
    char adress[56];
    int i = 0;
    while(true)
    {
        int key;
        cout << "\n1) Write to file; 2) Get info from file; 3) Read new file; 4) Show information; 5) Show odnofamilars ";
        cin >> key;
        switch(key)
        {
        case 1:
            {
                cout << "\nEnter adress to file: ";
                cin >> adress;
                fstream file;
                file.open(adress, ios::trunc | ios::out | ios::binary); //adress -> "d:/filename.*"   
                do                  
                {     
                    cout << "\nEnter name of person (LastName N N): ";    
                    pers.getdata();    
                    file.write(reinterpret_cast<char*>(&pers), sizeof(pers)); 
                    cout << "Next (y/n)? ";     
                    cin >> ch;     
                }   
                while(ch == 'y');
                system("pause");
                system("cls");
                file.close();
            };break;
 
        case 2:
            {
                cout << "\nEnter adress to file: ";
                cin >> adress;
                fstream file;
                file.seekg(0);   
                file.open(adress, ios::app | ios::in | ios::binary);  //adress -> "d:/filename.*" 
                file.read(reinterpret_cast<char*>(&pers), sizeof(pers));   
                while(!file.eof())
                {
                    {
                        arr[i] = pers;
                        i++;
                    }       
                    file.read(reinterpret_cast<char*>(&pers), sizeof(pers));       
                }
                file.close();
                cout << endl;
                system("cls");
            };
            break;
            case 3:
            {
                i = 0;
                cout << "\nEnter adress to file: ";
                cin >> adress;
                fstream file;
                file.seekg(0);   
                file.open(adress, ios::app | ios::in | ios::binary);   //adress -> "d:/filename.*" 
                file.read(reinterpret_cast<char*>(&pers), sizeof(pers));   
                while(!file.eof())
                {
                    {
                        arr[i] = pers;
                        i++;
                    }       
                    file.read(reinterpret_cast<char*>(&pers), sizeof(pers));       
                }
                file.close();
                cout << endl;
                system("cls");
            };
            break;
        case 4:
            {
                int j = 0;
                while(j < i)
                {
                    arr[j].showData();
                    j++;
                }
                system("pause");
            };
            break;
        case 5:
            {
                person tmp[C];  // создаю новый временный массив обьектов
                for (int I = 0; I < C; I++) // копирую в него данные из основного массива
                {
                    tmp[I] = arr[I];
                }
                for(int J = 0; J < C; J++)  // проверка елемента
                {
                    for (int j = 0; j < C; j++) // с другими елементами массива
                    {
                        if ( (strcmp(tmp[J].return_(), tmp[j].return_()) == 0)   &&   tmp[j].ret_anav() == true ) // если фамилии совпали, и такой елемент еще не провереный
                        {
                            tmp[j].showData(); //  показать елемент
                            tmp[J].make_false(); // если елемент подходит делаем провереным
                        };
                    }
                    tmp[J].make_false(); // сделать елемент "провереным"
                    //tmp[J].~person(); // 
                }
            };
            break;
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru