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

Сортировка структуры сотрудников по убыванию стажа - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
ETALONMAX
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 9
07.10.2013, 00:30     Сортировка структуры сотрудников по убыванию стажа #1
Доброго времени суток!

Уже обыскался весь форум на наличие рабочей программы по данной структурной сортировке сотрудников. Помогите пожалуйста.

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

Заранее благодарен!

Добавлено через 11 часов 32 минуты
Ап ночной
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.10.2013, 00:30     Сортировка структуры сотрудников по убыванию стажа
Посмотрите здесь:

Структуры... Задача: "База сотрудников небольшой фирмы" C++
Структуры. Сортировка массива структуры C++
Структуры: база данных сотрудников фирмы C++
[структуры] В анкетах сотрудников некоторого учреждения имеются следующие сведения C++
C++ Для 10 сотрудников отдела: выполнить сортировку по убыванию номеров телефонов
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ArmanPrestige
 Аватар для ArmanPrestige
219 / 210 / 50
Регистрация: 15.01.2013
Сообщений: 788
07.10.2013, 02:49     Сортировка структуры сотрудников по убыванию стажа #2
Что конкретно не получается?
ETALONMAX
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 9
07.10.2013, 10:51  [ТС]     Сортировка структуры сотрудников по убыванию стажа #3
Я не занимаюсь программированием на C++, язык не интересен, вот не получается ничего
Код с Киберфорума преподавателю не понравился, нужно какой-то поменьше наверное
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
#include <iostream>
#include <string.h>
#include <conio.h>
 
using namespace std;
 
int main(void)
{
    setlocale(LC_ALL, "Russian");
char *str1 = "Введите количество сотрудников: ";
char *str2 = "Введите Ф.И.О. сотрудника: ";
char *str3 = "Введите номер отдела: ";
char *str4 = "Введите должность сотрудника: ";
char *str5 = "Введите день с которого сотрудник начал работу: ";
char *str6 = "Введите месяц с которого сотрудник начал работу: ";
char *str7 = "Введите год с которого сотрудник начал работу в формате гггг: ";
char *str8 = "Введите номер отдела что бы увидеть информацию о сотрудниках данного отдела: ";
 
struct sotrudniki
{
       char fio[40];
       char nomerotdela[2];
       char dolshnost[20];
       int date[3];
}
msotrudniki[100];
 
// Количество сотрудников
int n;
// Переменные для итерации цикла
int i, k;
 
int date1, date2;
 
// Переменная для указания номера отдела
int numotdel;
 
sotrudniki temp;
    
    cout << str1;
    cin >> n;
    
    // Заполняем структуру
    for (i = 0; i < n; i++)
    {
        cout << str2;
        cin >> msotrudniki[i].fio;
        
        cout << str3;
        cin >> msotrudniki[i].nomerotdela;
        
        cout << str4;
        cin >> msotrudniki[i].dolshnost;
        
        cout << str5;
        cin >> msotrudniki[i].date[0];
        
        cout << str6;
        cin >> msotrudniki[i].date[1];
        
        cout << str7;
        cin >> msotrudniki[i].date[2];
    }
 
    // Сортировка
    k = n-1;
    bool flag = true;
 
    while (flag)
    {
        flag = false;
        for (i = 0; i < k; i++)
        {
            date1 = msotrudniki[i].date[2]*10000 + msotrudniki[i].date[1]*100 + msotrudniki[i].date[0];
            date2 = msotrudniki[i+1].date[2]*10000 + msotrudniki[i+1].date[1]*100 + msotrudniki[i+1].date[0];
 
            if (date1 > date2)
            {
               temp = msotrudniki[i];
               msotrudniki[i] = msotrudniki[i+1];
               msotrudniki[i+1] = temp;
               flag = true;
            }
        }
        k--;
        if (k < 0)
           flag = false;
    }
    
    cout << str8;
    cin >> numotdel;
        // Вывод
    for (i = 0; i < n; i++)
    {
           if (atoi(msotrudniki[i].nomerotdela) == numotdel)
           cout << msotrudniki[i].fio << " " << msotrudniki[i].dolshnost << " " <<  msotrudniki[i].date[0] << "." << msotrudniki[i].date[1] << "." << msotrudniki[i].date[2] << endl;
    }
        _getch();
    return 0;}
correcеt
 Аватар для correcеt
-1 / 3 / 1
Регистрация: 20.04.2011
Сообщений: 412
29.03.2016, 16:29     Сортировка структуры сотрудников по убыванию стажа #4
ETALONMAX, Вывести списки сотрудников по отделам в порядке убывания стажа. Ключ: дата начала работы
данный пункт не учли в коде,наверное
Yandex
Объявления
29.03.2016, 16:29     Сортировка структуры сотрудников по убыванию стажа
Ответ Создать тему
Опции темы

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