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

Отсортировать по алфавиту - C++

Восстановить пароль Регистрация
 
I_Masha_I
2 / 2 / 0
Регистрация: 14.10.2012
Сообщений: 53
16.11.2012, 21:08     Отсортировать по алфавиту #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
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
#include "stdafx.h"
#include <locale>
#include <iostream>
#include <iomanip>
#include <fstream>
using namespace std;
 
ifstream in("input.txt");
ofstream out("output.txt");
 
void print_file(char* name) //функция вывода на экран из файла
{
 fstream file(name);
 char* str = new char [255];
 while (file.peek()!= EOF)
  {
  file.getline(str,255);
   cout<<(str)<<endl;
  }
}
 
struct mas
{
    string fam;
    int gr, ses[3];
    char alfavit;
    void print();
};
void mas::print()//вывод данных в выходной поток
{
    out<<setw(12)<<left<<fam<<setw(10)<<gr;
    for (int i=0;i<3;i++)
        out<<setw(3)<<ses[i];
    out<<setw(5)<<alfavit<<endl;
}
void sort(mas *a,int n)
{
    mas temp;
    char lowkey;//текущий наименьший ключ, найденный при проходе по элекментам а[i],...,a[n]
    int lowindex;//позиция элемента с ключом lowkey
    int i,j;
    for (i=0;i<n-1;i++)
    {
        lowindex=i; 
        lowkey=a[i].alfavit;
        for (j=i+1;j<n;j++)
            if (a[j].alfavit>lowkey) 
            {
                lowkey=a[j].alfavit;
                lowindex=j;
            }
            temp=a[i]; 
            a[i]=a[lowindex]; 
            a[lowindex]=temp;
    }
}
int main()
{
    setlocale(LC_ALL, "Russian");
    int n=0, i;
    mas stud[20];
    if (!in) cout<<"Error\n";
    else
    {
        while(in.peek()!=EOF)
        {
            in>>stud[n].fam;
            in>>stud[n].gr;
            stud[n].alfavit=0;
            for (i=0;i<3;i++)
            {
                in>>stud[n].ses[i];
                stud[n].alfavit+=stud[n].ses[i];
            }
            n++;
        }
        sort(stud,n);
        for (i=0;i<n;i++)
            stud[i].print();
    }
    print_file("output.txt");
    in.close(); 
    out.close();
    system("PAUSE");
    return 0;
}
Например для файла:
1C
1
2
3
Иванов 77 5 4 5
Андреев 78 5 3 3    
Васильев 88 3 5 4
Должно выводиться:
1C
1
2
3
4
           
Андреев     78        5  3  3 
Васильев    88        3  5  4  
Иванов      77        5  4  5
А у меня выводит:
1C
1
2
3
Иванов      77        5  4  5      
Васильев    88        3  5  4      
Андреев     78        5  3  3
Я сортировала алгоритмом метод выбора, по-моему написала правильно, пожалуйста укажите в чём ошибка!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.11.2012, 21:08     Отсортировать по алфавиту
Посмотрите здесь:

C++ Отсортировать слова в строке по алфавиту
отсортировать слова по алфавиту C++
C++ Отсортировать слова в предложении по алфавиту
Отсортировать ФИО по алфавиту C++
Отсортировать имена по алфавиту C++
C++ Отсортировать структуру по алфавиту
Как строки отсортировать по алфавиту с++ C++
C++ Отсортировать строки по алфавиту

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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