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

Помощь в сортировке - C++

Восстановить пароль Регистрация
 
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 02:01     Помощь в сортировке #1
Здравствуйте, товарищи программисты. Знаю, что вам уже всем надоело натыкаться на подобные темы со структурой ZNAK, но все же! Написал прогу по считыванию данных с файла и вывод на экран человека, месяц которого мы вводим с клавиатуры. Вообщем прошу помочь с сортировкой. Задание заключается в следующем: записи должны быть упорядочены по знакам зодиака. Файл с текстом прикрепил(откуда идет считывание). Спасибо заранее.

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
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std; 
 
struct ZNAK // объявление структуры ZNAK
{
    char l_name[100]; // имя и фамилия
    char l_zodiak[15]; // знак зодиака
    int l_bday[3]; // дата рождения
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8; // количество записей ( должно быть 8 )
ZNAK book[size_array];
int counter_rec = 0; // счётчик записей
 
    char buf[100];
 
    FILE*file=fopen("C:\\7.5\\7.5\\123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        cout << book[counter_rec].l_name; // имя и фамилия
        cout << book[counter_rec].l_zodiak; // знак зодиака
        cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // дата рождения
    }
 
 
    cout << endl;
    int month = 0;
    cout << "Введите порядковый номер месяца: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Месяц указан не корректно!" << endl;
                    //return 0;
        }
    else
    {
        // печать записей, месяц которых совпадает с введённым
        cout << endl;
        bool no_records = false; // переменная-флаг, отвечающая за существование записей, месяц которых равен введённому
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month) // если совпадает номер месяца в записи с введённым с клавиатуры
            {
                no_records = true;
                cout << book[counter_rec].l_name; // имя и фамилия
                cout << book[counter_rec].l_zodiak; // знак зодиака
                cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // дата рождения
            }
        }
            if (!no_records) cout << "Нет людей родившихся " << month << " месяца." << endl;
    }
 
       
 
system("pause");
return 0;
}
Вложения
Тип файла: txt 123.txt (301 байт, 3 просмотров)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.11.2012, 02:01     Помощь в сортировке
Посмотрите здесь:

Очередной вопрос по сортировке.. C++
Счетчик в сортировке C++
Информация о карманной сортировке C++
C++ Ошибка в порязрядной сортировке?!
C++ Ошибка в сортировке
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 15:24  [ТС]     Помощь в сортировке #2
up up
есть такая же прога с сортировкой,но там с клавиатры клавиатуры вводится
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
18.11.2012, 17:11     Помощь в сортировке #3
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
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std; 
 
struct ZNAK
{
    char l_name[100];
    char l_zodiak[15];
    int l_bday[3];
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8;
ZNAK book[size_array],sort[size_array];
int counter_rec = 0;
 
    char buf[100];
    int k=0;
 
    FILE*file=fopen("C:\\7.5\\7.5\\123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        cout << book[counter_rec].l_name;
        cout << book[counter_rec].l_zodiak;
        cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
    }
 
 
    cout << endl;
    int month = 0;
    cout << "Месяц: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Ошибка!" << endl;
 
        }
    else
    {
 
        cout << endl;
        bool no_records = false;
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month)
            {
                no_records = true;
                sort[k].l_name=book[counter_rec].l_name;
                sort[k].l_zodiak=book[counter_rec].l_zodiak;
                sort[k].l_bday[0]=book[counter_rec].l_bday[0];
                sort[k].l_bday[1]=book[counter_rec].l_bday[1];
                sort[k].l_bday[2]=book[counter_rec].l_bday[2];
                k++;
 
            }
        }
        //+++++++++++++++++++++++++++++++++
                if (!no_records) cout << "Нет людей род " << month << " месяце." << endl;
                else
                {for (int i = 0; i < k; i++)
                 {
                if(sort[i].l_bday[0]<=22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }
                if(sort[i].l_bday[0]>22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }}
 
                }
    }
 
       
 
system("pause");
return 0;
}
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 17:17  [ТС]     Помощь в сортировке #4
Цитата Сообщение от Amandosov Посмотреть сообщение
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
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std; 
 
struct ZNAK
{
    char l_name[100];
    char l_zodiak[15];
    int l_bday[3];
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8;
ZNAK book[size_array],sort[size_array];
int counter_rec = 0;
 
    char buf[100];
    int k=0;
 
    FILE*file=fopen("C:\\7.5\\7.5\\123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        cout << book[counter_rec].l_name;
        cout << book[counter_rec].l_zodiak;
        cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
    }
 
 
    cout << endl;
    int month = 0;
    cout << "Месяц: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Ошибка!" << endl;
 
        }
    else
    {
 
        cout << endl;
        bool no_records = false;
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month)
            {
                no_records = true;
                sort[k].l_name=book[counter_rec].l_name;
                sort[k].l_zodiak=book[counter_rec].l_zodiak;
                sort[k].l_bday[0]=book[counter_rec].l_bday[0];
                sort[k].l_bday[1]=book[counter_rec].l_bday[1];
                sort[k].l_bday[2]=book[counter_rec].l_bday[2];
                k++;
 
            }
        }
        //+++++++++++++++++++++++++++++++++
                if (!no_records) cout << "Нет людей род " << month << " месяце." << endl;
                else
                {for (int i = 0; i < k; i++)
                 {
                if(sort[i].l_bday[0]<=22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }
                if(sort[i].l_bday[0]>22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }}
 
                }
    }
 
       
 
system("pause");
return 0;
}
Выкинуло ошибку
Честно, посмотрев код,даже не понял что и как сортируется.Допустим "Овен" есть первый знак зодиака, значит запись с таким знаком зодиака должна быть первой при сортировке.
Миниатюры
Помощь в сортировке  
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 17:23  [ТС]     Помощь в сортировке #5
Вот прога которая работает при вводе с клавиатуры.Весь функционал выполняет что нужно, но мне надо чтобы читало с файла.Пробовал переставлять туда с помощью чтения с файла, но тогда не сортирует.

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
166
167
168
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std;
 
int getIntZodiak(char * str); // прототип функции, которая возвращает порядковый номер знака зодиака 
 
struct ZNAK // объявление структуры ZNAK
{
    char l_name[50]; // имя и фамилия
    char l_zodiak[12]; // знак зодиака
    int l_bday[3]; // дата рождения
};
 
const char *sign_zodiak[12] = {"Oven", "Telec", "Bliznec", "Rak" , "Lev", "Deva",
                         "Vesy", "Scorpion", "Strelec", "Kozerog", "Vodoley", "Ryby" }; // порядок следования знаков зодиака
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 2; // количество записей ( должно быть 8 )
ZNAK book[size_array]; // объявляем массив структур
int counter_rec = 0; // счётчик записей
 
cout << "Сортировать будем в следующей последовательности: " << endl;
cout << " 1. Oven (Овен)" << ' ' << "        2. Telec (Телец) " << ' ' << "       3. Bliznec (Близнецы) " << endl
     << " 4. Rak (Рак)  "<< ' ' << "        5. Lev (Лев) " << ' ' << "           6. Deva (Дева) " << endl
    << " 7. Vesy (Весы)"<< ' ' << "        8. Scorpion (Скорпион) " << ' ' << " 9. Strelec (Стрелец) " << endl
    << " 10. Kozerog (Козерог)"<< ' ' << " 11. Vodoley (Водолей) " << ' ' << "  12. Ryby (Рыбы) " << endl;
 
 
while (counter_rec < size_array) // пока не внесено 8 записей
    {
                cout << "Введите имя и фамилию через пробел: ";
                cin.getline(book[counter_rec].l_name, 50);
                cout << "Введите знак зодиака: ";
                cin.getline(book[counter_rec].l_zodiak, 12);
 
                bool exist = false;
 
                for (int counter = 0; counter < 12; counter++)
                    {
                        if (!strcmp(sign_zodiak[counter], book[counter_rec].l_zodiak))
                            exist = true;
                    }
                if (exist) 
                {
                    cout << "Введите дату рождения в формате (дд.мм.гггг) ";
                    cin >> (book[counter_rec].l_bday[0]); // считать первые два символа, т.е. день
                    cin.ignore(); // пропустить символ точки
                    if (book[counter_rec].l_bday[0]<1 || book[counter_rec].l_bday[0]>31)
                        {
                            cout << "Вы ввели неверное число дд. ! " << endl;
                            system("pause");
                            return 0;
                        }
                    else
                    {
                            cin >> book[counter_rec].l_bday[1]; // считать следующие два символа, т.е. месяц
                            cin.ignore(); // пропустить символ точки
                            if (book[counter_rec].l_bday[1]<1 || book[counter_rec].l_bday[1]>12)
                                {
                                    cout << "Вы ввели неверное число мм. ! " << endl;
                                    system("pause");
                                    return 0;
                                }
                            else
                                {
                                    cin >> book[counter_rec].l_bday[2]; // считать четыре символа, т.е. год
                                    cin.get(); // считываем символ новой строки '\n'
 
                                    counter_rec++; // инкремент счётчика записей
                                }
                    }
                }
                else
                    return 0;
    }
 
// сортировка записей в массиве структур
    for (int ctr1 = 0; ctr1 < size_array; ctr1++)
    {
        for (int ctr2 = ctr1 + 1; ctr2 < size_array; ctr2++)
        {
            if (getIntZodiak(book[ctr1].l_zodiak) > getIntZodiak(book[ctr2].l_zodiak)) // если порядок не правильный, то поменять местами записи
            {
                char temp_name[50]; // временная переменная для перестановки строк: имя и знак зодиака
 
                // перестановка имён
                strcpy(temp_name, book[ctr1].l_name); // копирование из book[ctr1].l_name в temp_name
                strcpy(book[ctr1].l_name, book[ctr2].l_name); // копирование из book[ctr2].l_name в book[ctr1].l_name
                strcpy(book[ctr2].l_name, temp_name); // копирование из temp_name в book[ctr2].l_name
 
                // перестановка знака зодиака
                strcpy(temp_name, book[ctr1].l_zodiak); // копирование из book[ctr1].l_zodiak в temp_name
                strcpy(book[ctr1].l_zodiak, book[ctr2].l_zodiak); // копирование из book[ctr2].l_zodiak в book[ctr1].l_zodiak
                strcpy(book[ctr2].l_zodiak, temp_name); // копирование из temp_name в book[ctr2].l_zodiak
 
                int temp_data[3] = {book[ctr1].l_bday[0], book[ctr1].l_bday[1], book[ctr1].l_bday[2]}; // временный массив, для обмена д.р.
 
                // перестановка дат рождения
                book[ctr1].l_bday[0] = book[ctr2].l_bday[0];
                book[ctr1].l_bday[1] = book[ctr2].l_bday[1];
                book[ctr1].l_bday[2] = book[ctr2].l_bday[2];
                book[ctr2].l_bday[0] = temp_data[0];
                book[ctr2].l_bday[1] = temp_data[1];
                book[ctr2].l_bday[2] = temp_data[2];
 
            }
            
        }
 
    }   
 
    cout << endl;
    for (int counter = 0; counter < size_array; counter++)
    {
    cout << book[counter].l_name << endl; // имя и фамилия
    cout << book[counter].l_zodiak << endl; // знак зодиака
    cout << book[counter].l_bday[0] << "." << book[counter].l_bday[1] << "." << book[counter].l_bday[2] << endl; // дата рождени
    }
 
 
    cout << endl;
    int month = 0;
    cout << "Введите порядковый номер месяца: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Месяц указан не корректно!" << endl;
                    //return 0;
        }
    else
    {
        // печать записей, месяц которых совпадает с введённым
        cout << endl;
        bool no_records = false; // переменная-флаг, отвечающая за существование записей, месяц которых равен введённому
        for (int counter = 0; counter < size_array; counter++)
        {
            if (book[counter].l_bday[1] == month) // если совпадает номер месяца в записи с введённым с клавиатуры
            {
                no_records = true;
                cout << book[counter].l_name << endl; // имя и фамилия
                cout << book[counter].l_zodiak << endl; // знак зодиака
                cout << book[counter].l_bday[0] << "." << book[counter].l_bday[1] << "." << book[counter].l_bday[2] << endl; // дата рождения
            }
        }
            if (!no_records) cout << "Нет людей родившихся " << month << " месяца." << endl;
    }
 
       
 
system("pause");
return 0;
}
 
int getIntZodiak(char *str) // функция возвращает порядковый номер знака зодиака
{
    for (int counter = 0; counter < 12; counter++)
    {
        if (!strcmp(str ,sign_zodiak[counter])) // если знаки зодиака совпадают, то вернуть порядковый номер
            return counter;
    }
    return 0; // возвращаемое значение, в случае, если имя передоваемое как параметр не совпало ни с одним знаком зодиака
}
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
18.11.2012, 17:42     Помощь в сортировке #6
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
166
167
168
169
170
171
172
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std; 
 
struct ZNAK
{
    char l_name[100];
    char l_zodiak[15];
    int l_bday[3];
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8;
ZNAK book[size_array],sort[size_array];
int counter_rec = 0;
 
    char buf[100];
    int k=0;
 
    FILE*file=fopen("C:\\7.5\\7.5\\123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        if (book[counter_rec].l_bday[1] == 1&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 12&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 2&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 1&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 2&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 5&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 6&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 5&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 7&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 6&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 8&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 7&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 9&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 8&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 10&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 9&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 11&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 10&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 12&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 11&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
 
    }
 
 
    cout << endl;
    int month = 0;
    cout << "month: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Error!" << endl;
 
        }
    else
    {
 
        cout << endl;
        bool no_records = false;
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month)
            {
                no_records = true;
                sort[k].l_name=book[counter_rec].l_name;
                sort[k].l_zodiak=book[counter_rec].l_zodiak;
                sort[k].l_bday[0]=book[counter_rec].l_bday[0];
                sort[k].l_bday[1]=book[counter_rec].l_bday[1];
                sort[k].l_bday[2]=book[counter_rec].l_bday[2];
                k++;
 
            }
        }
        //+++++++++++++++++++++++++++++++++
                if (!no_records) cout << "Empty " << month << " month." << endl;
                else
                {for (int i = 0; i < k; i++)
                 {
                if(sort[i].l_bday[0]<=22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }
                if(sort[i].l_bday[0]>22)
                 {
                  cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
                 }}
 
                }
    }
 
       
 
system("pause");
return 0;
}
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 17:47  [ТС]     Помощь в сортировке #7
Не знаю в чем дело, но все та же ошибка в sort(скрин с ошибкой выше)
errror:выражение должно быть допустимым для изменения левосторонним значением
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
18.11.2012, 18:04     Помощь в сортировке #8
Poprobui eto, pomoemu pravilno
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
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std; 
 
struct ZNAK
{
    char l_name[100];
    char l_zodiak[15];
    int l_bday[3];
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8;
ZNAK book[size_array],sort[size_array];
int counter_rec = 0;
 
    char buf[100];
    int k=0;
 
    FILE*file=fopen("C:123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        if (book[counter_rec].l_bday[1] == 1&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 12&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 2&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 1&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 2&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 5&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 6&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 5&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 7&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 6&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 8&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 7&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 9&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 8&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 10&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 9&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 11&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 10&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
        if (book[counter_rec].l_bday[1] == 12&&book[counter_rec].l_bday[0] <=22||book[counter_rec].l_bday[1] == 11&&book[counter_rec].l_bday[0] >22)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // ???? ????????
        }
 
    }
 
 
    cout << endl;
    int month = 0;
    cout << "month: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Error!" << endl;
 
        }
    else
    {
 
        cout << endl;
        bool no_records = false;
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month)
            {
                no_records = true;
                cout << sort[k].l_name;
                  cout << sort[k].l_zodiak;
                  cout << sort[k].l_bday[0] << "." << sort[k].l_bday[1] << "." << sort[k].l_bday[2] << endl << endl;
            }
        }
               if (!no_records) cout << "Empty " << month << " month." << endl;
 
 
    }
 
 
 
system("pause");
return 0;
}
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 18:04  [ТС]     Помощь в сортировке #9
Вот ошибка
Миниатюры
Помощь в сортировке  
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 18:10  [ТС]     Помощь в сортировке #10
Проблема была в расположении файла.Запустил,ввожу месяц и понеслись фэйлы


Как ты сортируешь,можешь объяснить алгоритм?)
Миниатюры
Помощь в сортировке  
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
18.11.2012, 18:38     Помощь в сортировке #11
у меня там маленькая ошибка в алгоритме,а правильный алгоритм примерно так ну например начиная с Овна должен быть (месяц=3 и день>21) или (месяц=4 и день<=20)и т.д., (в гороскопе посмотришь)

C++
1
2
3
4
5
6
7
for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {if (book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0]>21 ||book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] <=20)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl;
        }...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.11.2012, 21:50     Помощь в сортировке
Еще ссылки по теме:

Ошибка в сортировке C++
Ошибка в пирамидальной сортировке C++
C++ Ошибка в быстрой сортировке

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Adm!n
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 17
18.11.2012, 21:50  [ТС]     Помощь в сортировке #12
Цитата Сообщение от Amandosov Посмотреть сообщение
у меня там маленькая ошибка в алгоритме,а правильный алгоритм примерно так ну например начиная с Овна должен быть (месяц=3 и день>21) или (месяц=4 и день<=20)и т.д., (в гороскопе посмотришь)

C++
1
2
3
4
5
6
7
for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {if (book[counter_rec].l_bday[1] == 3&&book[counter_rec].l_bday[0]>21 ||book[counter_rec].l_bday[1] == 4&&book[counter_rec].l_bday[0] <=20)
        {
         cout << book[counter_rec].l_name;
         cout << book[counter_rec].l_zodiak;
         cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl;
        }...
Там собственно задание в другом заключалось
Вообщем смотри,мы считали инфу с файла.Знаки зодиака в разнобой идут.Дата к ним вообще никак не подвязывается,т.е. не надо определить знак зодиака по дате.Допустим я задал так,что Овен будет первым,потом за ним телец.Прога запустит цикл и проверит,если найдет овна,выведет его на первое место,тельца на второе.

Попробуй скомпиль мою прогу,где ввод с клавиатуры.Выкладывал выше.

Введи aaa aaa
Kozerog
31.12.1990

bbb bbb
Oven
12.10.1222

и посмотри как он отсортирует)
он должен поменять их местами

Добавлено через 21 минуту
Не знаю даже,почему он не сортирует,если взять фрагмент кода где считывания с файла и заменить его в то место где ввод с клавиатуры.Вроде все то же самое,выводит массив,вводишь месяц,выдает людей с этим месяцем,а сортировать отказывается(

Добавлено через 2 часа 42 минуты
Помогли на другом форуме,но снова не сортирует, что за ..!

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
#include <iostream>
#include <iomanip>
#include <cstring>
 
using namespace std;
 
 
struct ZNAK // объявление структуры ZNAK
{
    char l_name[100]; // имя и фамилия
    char l_zodiak[15]; // знак зодиака
    int  l_bday[3]; // дата рождения
 
};
 
int main()
{
 
setlocale ( LC_ALL, "Russian" );
 
const int size_array = 8; // количество записей ( должно быть 8 )
ZNAK book[size_array];
int counter_rec = 0; // счётчик записей
 
cout << "Сортировать будем в следующей последовательности: " << endl;
cout << " 1. Oven (Овен)" << ' ' << "        2. Telec (Телец) " << ' ' << "       3. Bliznec (Близнецы) " << endl
     << " 4. Rak (Рак)  "<< ' ' << "        5. Lev (Лев) " << ' ' << "           6. Deva (Дева) " << endl
    << " 7. Vesy (Весы)"<< ' ' << "        8. Scorpion (Скорпион) " << ' ' << " 9. Strelec (Стрелец) " << endl
    << " 10. Kozerog (Козерог)"<< ' ' << " 11. Vodoley (Водолей) " << ' ' << "  12. Ryby (Рыбы) " << endl;
 
    char buf[100];
 
    FILE*file=fopen("C:\\7.5\\7.5\\123.txt","r");
 
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
        fgets(book[counter_rec].l_name,100,file);
        fgets(book[counter_rec].l_zodiak,15,file);
        fgets(buf,100,file);
        book[counter_rec].l_bday[0]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[1]=atoi(buf);
        fgets(buf,100,file);
        book[counter_rec].l_bday[2]=atoi(buf);
    }
 
 
 
const char *sign_zodiak[12] = {"Oven", "Telec", "Bliznec", "Rak" , "Lev", "Deva",
                         "Vesy", "Scorpion", "Strelec", "Kozerog", "Vodoley", "Ryby" }; // порядок следования знаков зодиака
 
// сортировка записей в массиве структур
    for (int ctr1 = 0; ctr1 < size_array; ctr1++)
    {
        for (int ctr2 = ctr1 + 1; ctr2 < size_array; ctr2++)
        {
            int i=0,j=0;
            for(;i<12;i++)  if (!strcmp(book[ctr1].l_zodiak ,sign_zodiak[i])) break;
            for(;j<12;j++)  if (!strcmp(book[ctr2].l_zodiak ,sign_zodiak[j])) break;
            if(i<12 && j<12)
            { 
                if(i<j)
                {
                    ZNAK t;
                    memcpy(&t,&book[ctr1],sizeof(book[ctr1]));
                    memcpy(&book[ctr1],&book[ctr2],sizeof(book[ctr1]));
                    memcpy(&book[ctr2],&t,sizeof(book[ctr1]));
                }   
            }
        }
    }   
 
 
    cout << endl;
    for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
    {
    cout << book[counter_rec].l_name; // имя и фамилия
    cout << book[counter_rec].l_zodiak; // знак зодиака
    cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // дата рождени
    }
 
 
    cout << endl;
    int month = 0;
    cout << "Введите порядковый номер месяца: ";
    cin >> month;
    if (month < 1 || month > 12)
        {
            cout << "Месяц указан не корректно!" << endl;
                    //return 0;
        }
    else
    {
        // печать записей, месяц которых совпадает с введённым
        cout << endl;
        bool no_records = false; // переменная-флаг, отвечающая за существование записей, месяц которых равен введённому
        for (int counter_rec = 0; counter_rec < size_array; counter_rec++)
        {
            if (book[counter_rec].l_bday[1] == month) // если совпадает номер месяца в записи с введённым с клавиатуры
            {
                no_records = true;
                cout << book[counter_rec].l_name; // имя и фамилия
                cout << book[counter_rec].l_zodiak; // знак зодиака
                cout << book[counter_rec].l_bday[0] << "." << book[counter_rec].l_bday[1] << "." << book[counter_rec].l_bday[2] << endl << endl; // дата рождения
            }
        }
            if (!no_records) cout << "Нет людей родившихся " << month << " месяца." << endl;
    }
 
       
 
system("pause");
return 0;
}
Yandex
Объявления
18.11.2012, 21:50     Помощь в сортировке
Ответ Создать тему
Опции темы

Текущее время: 11:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru