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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
tokar2
25 / 25 / 1
Регистрация: 09.11.2012
Сообщений: 229
#1

Сортировка (исправить код) - C++

22.11.2012, 19:31. Просмотров 283. Ответов 4
Метки нет (Все метки)

Нужно упорядочить записи по алфавиту, но у меня только меняет местами name! Помогите исправить код!
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
#include <iostream>
#include <string.h>
#include <time.h>
using namespace std;
 
const int n=3;
 
struct worker{
       char name[20];
       char pos[20];
       int year;
       char month[10];
       };
       
void inp(worker []);
void out(worker []);
void sort(worker []);
void yer(worker []);
 
int main(){
    srand(time(0));
    worker tabl[n];
    inp(tabl);
    out(tabl);
    sort(tabl);
   // yer(tabl);
    system("pause");
    return 0;
}
 
void inp(worker tabl[n]){
     char* nam[6]={"Stepan","Petro","Andriy","Ivan","Seroga","Vasa"};
     char* po[5]={"Engineer","Foreman","Programmer","Homeless","Electrician"};
     int ye[5]={1995,1993,1987,1978,1999};
     char* mon[7]={"April","February","November","December","June","July","January"};
     for(int i=0;i<n;i++){
             strcpy(tabl[i].name,nam[rand()%6]);
             strcpy(tabl[i].pos,po[rand()%5]);
             tabl[i].year=ye[rand()%5];
             strcpy(tabl[i].month,mon[rand()%7]);
             }
             }
             
void out(worker tabl[n]){
     for(int i=0;i<n;i++){
     cout<<tabl[i].name<<endl;
     cout<<tabl[i].pos<<endl;
     cout<<tabl[i].year<<endl;
     cout<<tabl[i].month<<endl;
     cout<<endl;
     }
     }
/*void yer(worker tabl[n]){
     int a;
     cin>>a;
     for ( int i = 0; i < n; i++){
         if(tabl[i].year>a) 
         cout<<tabl[i].name<<endl;
         }
     }*/
void sort(worker tabl[n]){
     char* temp=new char;
     for ( int i = 0; i < n; i++)   
        for ( int j = 0; j < n; j++) 
        if(strcmp(tabl[i].name, tabl[j].name) < 0) 
        { 
            strcpy(temp, tabl[i].name); 
            strcpy(tabl[i].name, tabl[j].name); 
            strcpy(tabl[j].name, temp); 
        } 
     }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.11.2012, 19:31     Сортировка (исправить код)
Посмотрите здесь:

Сортировка (исправить код) - C++
Помогите с сортировкой! Нужно сортировать исходные данные по убыванию!! Простой массив сортировать могу, а тут никак не получается)...

Пузырьковая сортировка - исправить код - C++
У меня есть массив unsigned char *buffer = new unsigned char. И мне нужно реализовать пузырьковую сортировку (сравниваются значения...

Сортировка пузырьком. Исправить код - C++
Подскажите пжл. в чем ошибка, что не так написано, не хочет сортировать(( числа рандомно присваивает и на этом собственно все(( ...

Сортировка по алфавиту (исправить код) - C++
Помогите отсортировать структуру по алфавиту (сортировка по tabl.name)! У меня ошибку выдает (( #include &lt;iostream&gt; #include &lt;string.h&gt;...

сортировка массива (исправить код) - C++
Нужно отсортировать массив по убыванию bals, но даже не компилируется! #include &lt;iostream&gt; #include &lt;iomanip.h&gt; using namespace...

Отсортировать столбцы в массиве по уменьшению сумм четных чисел. Сортировка выбором. Исправить код - C++
Задача: Задать двумерный массив целых чисел m=5, n=6. Отсортировать столбцы в массиве по упаданию сум парных чисел. Сортировка выбором....

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
tokar2
25 / 25 / 1
Регистрация: 09.11.2012
Сообщений: 229
22.11.2012, 19:50  [ТС]     Сортировка (исправить код) #2
С сортировкой разобрался! Почему пропускает одно имя?
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 <string.h>
#include <time.h>
using namespace std;
 
const int n=3;
 
struct worker{
       char name[20];
       char pos[20];
       int year;
       char month[10];
       };
       
void inp(worker []);
void out(worker []);
void sort(worker []);
void yer(worker []);
 
int main(){
    srand(time(0));
    worker tabl[n];
    inp(tabl);
    out(tabl);
    sort(tabl);
   // yer(tabl);
    system("pause");
    return 0;
}
 
void inp(worker tabl[n]){
     char* nam[6]={"Atepan","Betro","Andriy","Ivan","Beroga","Vasa"};
     char* po[5]={"Engineer","Foreman","Programmer","Homeless","Electrician"};
     int ye[5]={1995,1993,1987,1978,1999};
     char* mon[7]={"April","February","November","December","June","July","January"};
     for(int i=0;i<n;i++){
             strcpy(tabl[i].name,nam[rand()%6]);
             strcpy(tabl[i].pos,po[rand()%5]);
             tabl[i].year=ye[rand()%5];
             strcpy(tabl[i].month,mon[rand()%7]);
             }
             }
             
void out(worker tabl[n]){
     for(int i=0;i<n;i++){
     cout<<tabl[i].name<<endl;
     cout<<tabl[i].pos<<endl;
     cout<<tabl[i].year<<endl;
     cout<<tabl[i].month<<endl;
     cout<<endl;
     }
     }
/*void yer(worker tabl[n]){
     int a;
     cin>>a;
     for ( int i = 0; i < n; i++){
         if(tabl[i].year>a) 
         cout<<tabl[i].name<<endl;
         }
     }*/
void sort(worker tabl[n]){
     worker temp1;
     char* temp=new char;
     for ( int i = 0; i < n; i++)   
        for ( int j = 0; j < n; j++) 
        if(strcmp(tabl[i].name, tabl[j].name) < 0) 
        { 
                temp1=tabl[j];
                tabl[j]=tabl[j+1];
                tabl[j+1]=temp1;
        } 
        for(int i=0;i<n;i++){
     cout<<tabl[i].name<<endl;
     cout<<tabl[i].pos<<endl;
     cout<<tabl[i].year<<endl;
     cout<<tabl[i].month<<endl;
     cout<<endl;
     }
     }
Сортировка (исправить код)
booker
23 / 23 / 2
Регистрация: 21.11.2012
Сообщений: 106
22.11.2012, 20:38     Сортировка (исправить код) #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void sort(worker tabl[n]){
     worker temp;
      for ( int i = 0; i < n; i++)   
        for ( int j = 0; j < n; j++) 
        if(strcmp(tabl[i].name, tabl[j].name) < 0) 
        { 
            strcpy(temp.name, tabl[i].name); 
            strcpy(tabl[i].name, tabl[j].name); 
            strcpy(tabl[j].name, temp.name); 
        } 
        for(int i=0;i<n;i++){
     cout<<tabl[i].name<<endl;
     cout<<tabl[i].pos<<endl;
     cout<<tabl[i].year<<endl;
     cout<<tabl[i].month<<endl;
     cout<<endl;
     }
     }
tokar2, я тебе в прошлой теме отписал, но ты не посмотрел, попробуй так)

Добавлено через 4 минуты
C++
1
2
3
4
5
6
7
8
9
10
11
12
void sort(worker tabl[n]){
     worker temp;
      for ( int i = 0; i < n; i++)   
        for ( int j = 0; j < n; j++) 
        if(strcmp(tabl[i].name, tabl[j].name) < 0) 
        { 
            strcpy(temp.name, tabl[i].name); 
            strcpy(tabl[i].name, tabl[j].name); 
            strcpy(tabl[j].name, temp.name); 
        } 
        
     }
tokar2
25 / 25 / 1
Регистрация: 09.11.2012
Сообщений: 229
22.11.2012, 20:46  [ТС]     Сортировка (исправить код) #4
booker, Мне нужно целую структуру переставить!

Добавлено через 29 секунд
А не только имена!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.11.2012, 21:47     Сортировка (исправить код)
Еще ссылки по теме:

Исправить ошибки в программе. Сортировка по убыванию - C++
Требуется сортировку одномерного массива.Элемент начало сортировки представим в виде 3^n.Элементы сортировки отрицательные...

Исправить код - C++
//#include&lt;iostream.h&gt; #include&quot;time.h&quot; #include&lt;string&gt; using namespace std; const double price=0.0025; const int N=3; const...

Исправить код - C++
t=s; while ((k = strstr(t, &quot;*&quot;)) != NULL &amp;&amp; isdigit(*(k + 1))) { strcpy (s1, t+1); *(t+1)='\0'; strcat (s, &quot; &quot;); ...

исправить код - C++
создать класс студент, сделать поис по оценке ругается на перем. a в мэйне #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include...

исправить на код С - C++
Здравствуйте, исправте пожалуйста программу на код С, кто может. Условие:Даны натуральное число n, действительные числа Х1,...,Хn(n&gt;=2)....

Исправить код - C++
void main () { const int size= 10; int a; srand(time(NULL)); for (int i = 0; i &lt; size; i++) a = rand() % 11 - 5; for...


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

Или воспользуйтесь поиском по форуму:
piande
3 / 3 / 0
Регистрация: 26.10.2012
Сообщений: 18
22.11.2012, 21:47     Сортировка (исправить код) #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
#include <iostream>
#include <string.h>
#include <time.h>
using namespace std;
 
const int n=3;
 
struct worker{
       char name[20];
       char pos[20];
       int year;
       char month[10];
       };
template <class X>          // Шаблонен клас
void swapargs(X &a, X &b)   // Разменя местата на два аргумента независимо от типът им
{ X temp;
    temp = a;               // Swap arguments
    a = b;
    b = temp;
}       
void inp(worker []);
void out(worker []);
void sort(worker []);
void yer(worker []);
 
int main(){
    srand(time(0));
    worker tabl[n];
    inp(tabl);
    out(tabl);
    sort(tabl);
   // yer(tabl);
    system("pause");
    return 0;
}
 
void inp(worker tabl[n]){
     char* nam[6]={"Stepan","Petro","Andriy","Ivan","Seroga","Vasa"};
     char* po[5]={"Engineer","Foreman","Programmer","Homeless","Electrician"};
     int ye[5]={1995,1993,1987,1978,1999};
     char* mon[7]={"April","February","November","December","June","July","January"};
     for(int i=0;i<n;i++){
             strcpy(tabl[i].name,nam[rand()%6]);
             strcpy(tabl[i].pos,po[rand()%5]);
             tabl[i].year=ye[rand()%5];
             strcpy(tabl[i].month,mon[rand()%7]);
             }
             }
             
void out(worker tabl[n]){
     for(int i=0;i<n;i++){
     cout<<tabl[i].name<<endl;
     cout<<tabl[i].pos<<endl;
     cout<<tabl[i].year<<endl;
     cout<<tabl[i].month<<endl;
     cout<<endl;
     }
     }
/*void yer(worker tabl[n]){
     int a;
     cin>>a;
     for ( int i = 0; i < n; i++){
         if(tabl[i].year>a) 
         cout<<tabl[i].name<<endl;
         }
     }*/
void sort(worker tabl[n]){
     char* temp=new char;
     for ( int i = 0; i < n; i++)   
        for ( int j = 0; j < n; j++) 
        if(strcmp(tabl[i].name, tabl[j].name) < 0) 
        { 
             swapargs(tabl[i].name,  tabl[j].name); 
             swapargs(tabl[i].pos,  tabl[j].pos); 
....
....
        } 
     }
Yandex
Объявления
22.11.2012, 21:47     Сортировка (исправить код)
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru