С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 14.10.2012
Сообщений: 53
1

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

16.11.2012, 21:08. Показов 653. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Создать таблицу - массив структур, содержащих сведения о студентах: фамилию, группу, оценки по информатике, математике и физике.
Организовать просмотр. Упорядочить список по заданному ключу - алфавит.
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
Я сортировала алгоритмом метод выбора, по-моему написала правильно, пожалуйста укажите в чём ошибка!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.11.2012, 21:08
Ответы с готовыми решениями:

Отсортировать слова по алфавиту
Задача: Есть строка из слов разделенных запятыми, в конце строки точка. Нужно отсортировать слова...

Отсортировать имена по алфавиту
Нужно отсортировать имена по алфавиту. В коде я переношу имена из структуры в новый массив теперь...

Отсортировать строки по алфавиту
Вводим строки, и на выводе получаем их в алфавитном порядке. Я что-то голову ломаю, не понимаю....

Отсортировать ФИО по алфавиту
Дана структура FIRMA, ФИО сотрудников, посада, год поступления на роботу. 1.Надо посортировать...

0
16.11.2012, 21:08
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.11.2012, 21:08
Помогаю со студенческими работами здесь

Отсортировать структуру по алфавиту
Вообще задание такое: Описать структуру с именем STUDENT, содержащую следующие поля: 1)фамилия и...

Отсортировать слова в предложении по алфавиту
Дано предложение с нескольких слов. Отсортировать слова в предложении по алфавиту

Отсортировать элементы структуры по алфавиту.
друзья, не подскажите как отортировать элементы структуры по алфавиту???

Как отсортировать по алфавиту структуру
Здравствуйте, мальчики. Я делала программу, которая содержит прайс лист: -названия товара...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru