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

Сортировка

04.05.2016, 20:23. Показов 483. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, люди добрые, помогите кто может.
Нужно написать структуру Абитуриентов, вывод тех кто подключились более x лет назад, и сортировку по алфавиту.
В общем, саму структуру я сделал и вывод, но вот беда, не могу никак отсортировать по алфавитному порядку.
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
// Laba3_var29.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#include <windows.h>
#include <stdio.h>
#include <cstdio>
 
using namespace std;
 
 
struct ABONENT{
    char fio[20];
    int nomer;
    int date[3];
};
 
void enter(ABONENT *ABON, int n);
void print(ABONENT *ABON, int n);
void filtr(ABONENT *ABON, int n, int x);
void sort(ABONENT *ABON, int n);
 
 
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
 
    int n, x;
    cout << "Сколько будет моделей: ";
    cin >> n;
    ABONENT *ABON = new ABONENT[n];
    enter(ABON, n);
    print(ABON, n);
 
    cout << "Введите x: "; cin >> x;
    cout << endl;
    filtr(ABON, n, x);
    cout << endl;
 
    cout << "Таблица после сортировки";
    sort(ABON, n);
    print(ABON, n);
 
    system("pause");
    return 0;
}
void enter(ABONENT *ABON, int n)
{
    for (int i = 0; i < n; i++)
    {
        cout << "Введите ФИО  " << i + 1 << "-го абонента : ";
        cin >> ABON[i].fio;
        cout << "Введите номер телефона ( без +) " << i + 1 << "-го абонента : ";
        cin >> ABON[i].nomer;
        cout << "Введите дату подключения " << i + 1 << "-го абонента : ";
        cin >> ABON[i].date[0];
        cin >> ABON[i].date[1];
        cin >> ABON[i].date[2];
    }
}
void print(ABONENT *ABON, int n)
{
    for (int i = 0; i < n; i++)
    {
        cout << "-------------------------------------------------------------------";
        cout << "\n№" << i + 1 << "|" << "ФИО " << ABON[i].fio << " | " << "Номер телефона: " << ABON[i].nomer << "|" << "Дата подключения: " << ABON[i].date[0] << "." << ABON[i].date[1] << "." << ABON[i].date[2] << "|";
        cout << endl;
    }
    cout << "-------------------------------------------------------------------";
    cout << endl;
}
void filtr(ABONENT *ABON, int n, int x)
{
    int kol = 0;
    for (int i = 0; i < n; i++)
    {
        if ((2016 - ABON[i].date[2])>x)
        {
            cout << "-------------------------------------------------------------------";
            cout << "\n№" << i + 1 << "|" << "ФИО " << ABON[i].fio << " | " << "Номер телефона: " << ABON[i].nomer << "|" << "Дата подключения: " << ABON[i].date[0] << "." << ABON[i].date[1] << "." << ABON[i].date[2] << "|";
            cout << endl;
            kol++;
        }
 
    }
    if (kol == 0)
        cout << "Таких абонентов нету";
    cout << endl;
}
void sort(ABONENT *ABON, int n)
{
    ABONENT p;
    for (int i = 0; i<n; i++)
    {
        for (int j = 0; j<n; j++)
        {
            if (strcmp(ABON[i].fio, ABON[j].fio)<0)
            {
                p = ABON[j];
                ABON[i] = ABON[j];
                ABON[j] = p;
            }
        }
    }
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
04.05.2016, 20:23
Ответы с готовыми решениями:

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

Сортировка слиянием. В каком куске кода происходит сортировка и каким именно образом?
Помогите, пожалуйста, разобраться. Подскажите в каком куске кода происходит сортировка и каким...

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

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

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

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

Сортировка Слиянием vs Быстрая Сортировка - что лучше
Народ, помогите разобраться какой из методов сортировки лучше &quot;Сортировка Слиянием&quot; или &quot;Быстрая...

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

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


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

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