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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ В чем ошибка http://www.cyberforum.ru/cpp-beginners/thread970057.html
Я, только начинаю изучать. Моя первая программа. ней есть ошибки. Исходный код и ошибки прилагаю. Помогите пожалуйста разобраться. Заранее спасибо. // // Conversion - Программа для...
C++ Составить программы с использованием 1 из 3 видов циклов 1. Цикл с предусловием. while<условие>do 2. Цикл с постусловием. do<условие>while 3. Цикл по параметру. Задача 1. Программа для вычисления F(x). F(x)=7{sin}^{2}x-\frac{1}{2}cos x Задача 2.... http://www.cyberforum.ru/cpp-beginners/thread970052.html
C++ Выравнивание матрицы
Доброго времени суток. Хотелось бы узнать, как сделать чтобы из этого: http://joxi.ru/fA9RUtg5CbDUc_0TDm0 получилось это http://joxi.ru/6w9RUtg5CbB8Z16Cw5c
Буквенный массив C++
Доброго времени суток. Хотелось бы узнать, можно ли сделать массив, который хранил бы символы (буквы), в примеру x1, x2, ... , y1, y2, ... ??
C++ Ошибка при работе с динамическим массивом http://www.cyberforum.ru/cpp-beginners/thread970019.html
ошибка heap corruption detected: after normal block "#355" Ситуация такая, научился работать с динамическим массивом, чтение, вывод на экран, запись. Решил применить его к своей программе -...
C++ Организация хранения и доступа к объектам разных классов Всем привет! Есть класс описывающий структуру и содержание документа Doc. Внутри документ состоит из блоков - таблица, текст, список и тд. Для описания блоков созданы базовый класс Block и... подробнее

Показать сообщение отдельно
ETALONMAX
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 9
07.10.2013, 10:51  [ТС]
Я не занимаюсь программированием на 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;}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru