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

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

Войти
Регистрация
Восстановить пароль
 
vodolazky
-12 / 0 / 0
Регистрация: 09.12.2011
Сообщений: 19
#1

Сортировка по алфовиту - C++

31.03.2012, 15:01. Просмотров 339. Ответов 1
Метки нет (Все метки)

помогите, как отсортировать по алфавиту фамилии по заглавной букве
вот мой код :

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
#include <iostream>
#include <conio.h>
#include <string.h>
using namespace std;
 
struct wk
{ 
    char sname [20];
    char name [30];
    int year;
    int oklad;
}w[7];
 
int main()
{
    
    int i,j;
    cout<<"Vvedite dannie o rabotnikah:"<<endl;
    for (i=0;i<7;i++)
    {
        cout<<"#"<<i+1<<"\nSName: ";
        cin>>w[i].sname;
        cout<<"Name: ";
        cin>>w[i].name;
        cout<<"Year: ";
        cin>>w[i].year;
        cout<<"Z/P: ";
        cin>>w[i].oklad;
    }
    
    cout<<endl;
    cout<<"Otdel kadrov"<<endl;
    for (i=0;i<7;i++)
    cout<<w[i].sname<<'\t'<<w[i].name<<'\t'<<w[i].year<<'\t'<<w[i].oklad<<endl;
     getch();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.03.2012, 15:01
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Сортировка по алфовиту (C++):

Сортировка Шелла. Написал программу, не могу понять, почему сортировка не выполняется - C++
Программа создает динамический массив с рандомным заполнением. Дальше выбор сортировок, пузырьком или сортировка Шелла. Вот она то и не...

Сортировка слиянием. В каком куске кода происходит сортировка и каким именно образом? - C++
Помогите, пожалуйста, разобраться. Подскажите в каком куске кода происходит сортировка и каким именно образом? #include &lt;iostream&gt; ...

Быстрая сортировка(сортировка Хоара). Отсортировать фрагмент массива - C++
Мне нужно отсортировать фрагмент массива, расположенный между первым и последним отрицательным элементом. Немогу понять как устоновить...

Быстрая сортировка (сортировка Хоара) для связных списков - C++
есть у кого готовый алгоритм? или подскажите как реализовать

Сортировка Шелла и пирамидальная сортировка для символов - C++
Здраствуйте, можете пожалуйста привести пример сортировок шелла и пиромидальной сортировки для символов, а то ничего не могу ...

2 сортировки: пирамидальная сортировка и сортировка слиянием - C++
Реализовать два улучшенных алгоритма сортировки. Для каждого алгоритма вычислить показатель качества сортировки (количество операций, т.е....

1
MrCold
855 / 753 / 71
Регистрация: 11.01.2012
Сообщений: 1,942
31.03.2012, 16:35 #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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <iostream>
#include <conio.h>
#include <string.h>
#include <cctype>
 
const int OSIZE = 7;
using namespace std;
 
struct wk
{ 
       char sname [100];
       char name [100];
       int year;
       int oklad;
} w[OSIZE];
 
void inputFun();
void  sortFun();
void   outFun();
 
 
int main()
{
 
     inputFun();
     sortFun();
        cout<<endl;
     outFun();
getch();
}
 
void inputFun(){
 
cout<<"Vvedite dannie o rabotnikah:"<<endl;
    int i = 0;
    for (;i < OSIZE;i++)
{
    cout<<"#"<<i+1<<"\nSName: ";
    cin>>w[i].sname;
    cout<<"Name: ";
    cin>>w[i].name;
    cout<<"Year: ";
    cin>>w[i].year;
     cout<<"Z/P: ";
     cin>>w[i].oklad;
}
}
 
void sortFun(){
 
         int i = 0;
         char sbuffer[100];
        char nbuffer[100];
        int yearbuf;
        int zpbuf;
        bool loop = true;
 
 while(loop){
 
    loop = false;
 
    for(;i < OSIZE;i++)
 
      if(tolower(w[i - 1].sname[0]) > tolower(w[i].sname[0])){       
 
        strcpy(sbuffer,w[i - 1].sname); 
        strcpy(nbuffer,w[i - 1].name); 
        yearbuf = w[i - 1].year;
        zpbuf = w[i - 1].oklad;
        //////////////////////////////
 
    strcpy(w[i - 1].sname,w[i].sname);
    strcpy(w[i - 1].name,w[i].name);
    w[i - 1].year = w[i].year;
    w[i - 1].oklad = w[i].oklad;
 
    ////////////////////////////////////
 
        strcpy(w[i].sname,sbuffer); 
        strcpy(w[i].name,nbuffer); 
        w[i].year = yearbuf;
         w[i].oklad = zpbuf;
 
        //////////////////////////////////
        loop = true;
 
      }
 
 }
}
 
void outFun(){
   cout<<"Otdel kadrov"<<endl;
     int i = 0;
      for (; i < OSIZE;i++)
cout<<w[i].sname<<'\t'<<w[i].name<<'\t'<<w[i].year<<'\t'<<w[i].oklad<<endl;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.03.2012, 16:35
Привет! Вот еще темы с ответами:

Быстрая сортировка (сортировка методом Хоара) - C++
Ввести массив x1,x2,...,x20 в диапазоне . Требуется расположить отрицательные элементы в порядке убывания. Вывести массивы до и после...

Сортировка вектора по полю(Сортировка вставками) - C++
Здравствуйте! Нужно написать сортировку вектора по полю weight класса tomato. Вот класс: #pragma once #include &lt;iostream&gt; ...

C/C++ FAQ :: Быстрая сортировка (сортировка Хоара) - C++
Вопрос, скорее академический, по мотивам реализации. Вот в faq приведена реализация этого метода сортировки на C++. В коде есть следующий...

Java Сортировка по алфовиту - Java SE
Добрый день, подскажите, пожалуйста, у меня не работает функция Zad2, которая отвечает за сортировку по алфавиту, как это можно исправить?...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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