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

Структура WORKER: напечатать фамилии тех работников со стажем меньше среднего - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как с помощью классов нарисовать очки? http://www.cyberforum.ru/cpp-beginners/thread1141292.html
Как с помощью классов нарисовать очки? Помогите пожалуйста
C++ Сформируйте массив C[n+m], состоящий из элементов массивов А и В, упорядоченный по возрастанию Хелп плиз) Даны два массива, упорядоченных по возрастанию: А и B. Сформируйте массив C, состоящий из элементов массивов А и В, упорядоченный по возрастанию. Не получается сама формировка... http://www.cyberforum.ru/cpp-beginners/thread1141244.html
C++ Создание теста. Реализовать подсчет правильных ответов
Добрый день, подскажите как закончить программу с написанием теста в С++, начало я сделала, в концу нужно чтобы был счетчик, чтобы сложились все правильные ответы. Если при 7 правильных ответов...
C++ Напечатать все не отрицательные и не превышающие 100 элементы массива
Дан массив. Напечатать: a) все не отрицательные элементы б) все элементы, не превышающие числа 100 Начало есть, нужен только вывод а и б #include <iostream> #include <vcl.h> #include...
C++ Заполнить массив случайными значениями, лежащими в диапазоне от 50 до 100 http://www.cyberforum.ru/cpp-beginners/thread1141220.html
Массив предназначен для хранения значений весов двадцати человек. С помощью датчика случайных чисел заполните массив целыми значениями, лежащими в диапазоне от 50 до 100 включительно.
C++ Warning C4244: =: преобразование "double" в "float", возможна потеря данных Возникла проблема Решаю лабу, написал код, выдает ошибку (warning C4244: =: преобразование "double" в "float", возможна потеря данных) Лабу срочно сдать надо. Что делать? Помогите срочно!!! ... подробнее

Показать сообщение отдельно
Valerangb3
1 / 1 / 0
Регистрация: 24.02.2014
Сообщений: 6

Структура WORKER: напечатать фамилии тех работников со стажем меньше среднего - C++

07.04.2014, 14:26. Просмотров 274. Ответов 0
Метки (Все метки)

Описать структуру с именем WORKER, с полями: фамилия, имя, долж-ность, год поступления на работу. Сформировать односвязный список. Затем напечатать элементы списка по возрастанию, используя в качестве первичного ключа – поле «год». Затем напечатать фамилии тех работников, чей стаж меньше среднего стажа всех сотрудников предприятия.

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
#include <stdio.h>
#include <windows.h>
#include <conio.h>
#include <iostream>
using namespace std;
struct TOVAR
{ char nazvanie[20];
int cena;
int kol;
TOVAR *next;
};
TOVAR *head=0; //адрес головы списка
TOVAR *current;
int main()
{
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
char c;
printf("Vvesti dannie o tovare? y/n");;
c=getche(); 
//формирование списка с клавиатуры
while (c=='y' || c=='Y') 
{
if (head) 
{ 
current->next=new TOVAR; 
current=current->next; 
}
else 
{ head=new TOVAR ; 
current=head; 
}
system("cls");
printf("\nvvesti danniet o tovare:\n");
printf("nazvanie:");
scanf("%s", current->nazvanie);
printf("cena:");
cin>>current->cena;
printf("kol:");
scanf("%d",&current->kol);
current->next=0;
printf("vvesti? y/n");
c=getche();
}
if(head)//если список не пуст
{
system("cls");
cout<<"spisok:\n";
current=head;
while(current!=0)
{ printf("naz: %10s, cena: %10d, kolvo: %4d\n",current->nazvanie,current->cena, current->kol);
current=current->next;
}
getch();
}
printf("sort...\nspisok sort:\n");
bool nonstop=true; // логическая переменная на продолжение сортировки
TOVAR *back=0; // переменная хранения предыдущего элемента (т.к. обратного адреса нет =( ...)
current=head;
while(nonstop)
{
nonstop=false;
current=head;
while(current!=0)
{
if(current->next!=0 && strcmp(current->nazvanie, current->next->nazvanie)>0)
{
if(current==head) // если первый - меняем первый элемент на последующий
{
head=head->next;
current->next=head->next;
head->next=current;
 
back=head; // станет предыдущим для следующей итерации...
}
else // иначе ЕСЛИ за ним идет последний - меняем элемент с последним
if(current->next->next==0)
{
current->next->next=current;
back->next=current->next;
current->next=0; // фактически выйдем из цикла
}
else // инача промежуточный элемент
{
back->next=current->next;
current->next=current->next->next;
back->next->next=current;
back=back->next; // предыдущий по переходу к следующему)))
}
nonstop=true; // т.к. заменаа прошла, то возможно будут еще... разрешаем цикл дальше
}
else // если критерий замены не прошел - сохнаняем предыдущий и переходим к следующему
{
back=current;
current=current->next;
}
}
}
cout<<"\nsort: \n";
current=head;
while(current!=0)
{ printf("naz: %10s, cena: %10d, kolvo: %4d\n",current->nazvanie,current->cena, current->kol);
current=current->next;
}
getch();
return 0;
}
Дак вот мне осталось только сделать вот что:"Затем напечатать фамилии тех работников, чей стаж меньше среднего стажа всех сотрудников предприятия."
Помогите пожалуйста, если можно объяснить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru