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

Вывести статистику из массива структур - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Построить массив только из значений, входящих в исходный более одного раза http://www.cyberforum.ru/cpp-beginners/thread1034960.html
Задан произвольный массив. Исходная информация записана в файле. Построить массив только из значений, входящих в него более одного раза.
C++ Удалить все символы "*", а символы, не являющиеся "*", удвоить Составить программу, которая вводит строку символов, выполняет ее обработку и затем выво- дит результаты. Удалить все символы "*", а символы, не являющиеся "*", удвоить http://www.cyberforum.ru/cpp-beginners/thread1034957.html
Одномерный массив C++
помогите пожалуйста) в с++ совсем не бум-бум) Одномерный массив B и преобразовать его следующим образом: 1) увеличить каждый элемент массива на максимальный элемент 2) найти индекс и значение последнего минимального элемента массива 3) отсортировать элементы массива по убыванию заранее спасибо всем!!)))
C++ Обработка массивов с использованием подпрограмм
Составить программу для решения задачи. Каждый элемент матрицы A(3,3) разделить на произведение ее не- четных отрицательных элементов
C++ Ввести двумерный массив A(N×N) , вывести его. Найти сумму положительных элементов расположенных в части массива одновременно как над главной, так и http://www.cyberforum.ru/cpp-beginners/thread1034939.html
Ввести двумерный массив A(N×N) , вывести его. Найти сумму положительных элементов расположенных в части массива одновременно как над главной, так и над побочной диагональю. Найденной суммой заменить элементы, расположенные в части массива одновременно под главной и побочной диагоналями
C++ Найти количество полных центнеров в заданной массе и количество оставшихся килограмм задача 1 Дана масса M в килограммах. Найти количество полных центнеров в ней и количество оставшихся килограмм. подробнее

Показать сообщение отдельно
snegok1233
0 / 0 / 0
Регистрация: 08.10.2013
Сообщений: 13

Вывести статистику из массива структур - C++

09.12.2013, 20:57. Просмотров 195. Ответов 0
Метки (Все метки)

Вот в чём нужно помочь :
Создать программу учета сотрудников.
О сотруднике необходимо хранить следующие данные:

- ФИО
- должность
- дата рождения.

Данные о сотрудниках следует хранить в массиве структур

Программа должна иметь следующее меню:
1. Вывод списка сотрудников
2. Редактирование
Добавление сотрудника
Удаление сотрудника
3. Запросы
Вывести данные о сотруднике с заданной фамилией
Вывести всех сотрудников, у которых день рождения в заданном месяце
4. Статистика
Общее количество сотрудников
Количество сотрудников в каждой должности
Количество молодых специалистов (до 35 лет)
Сделал 1 и 2 пункты.

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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
#include <stdio.h>
#include <stdlib.h>
#include <locale.h>  
#include <iostream>
 
#define MAX 100
 
struct addr {
  char name[30];
  char fam[40];
  char otch[20];
  char dolg[10];
  char dat[10];
  char mes [15];
  char god [4];
  unsigned long int zip;
} addr_list[MAX];
 
void init_list(void), enter(void);
void remove(void), list(void);
int menu_select(void), find_free(void);
 
int main(void)
{
setlocale(LC_ALL,"RUS");
  char choice;
 
  init_list(); /* инициализация массива структур */
  for(;;) {
    choice = menu_select();
    switch(choice) {
    case 1: enter();
        break;
    case 2: remove ();
        break;
    case 3: list();
        break;
    case 4: exit(0);
        break;
    }
  }
 
  return 0;
}
 
/* Инициализация списка. */
void init_list(void)
{ int t;
 
  for(t=0; t<MAX; ++t) addr_list[t].name[0] = '\0';
}
 
/* Получения значения, выбранного меню. */
int menu_select(void)
{
 
  char s[80];
  int c;
 
  printf("1. Введите имя\n");
  printf("2. Удалите имя\n");
  printf("3. Выведите список\n");
  printf("4. Выход\n");
  do {
    printf("\nВведите номер нужного пункта: ");
    gets(s);
    c = atoi(s);
  } while(c<0 || c>4);
  return c;
}
 
/* Ввод адреса в список. */
void enter(void)
{
  int slot;
  char s[80];
 
  slot = find_free();
 
  if(slot==-1) {
    printf("\nСписок заполнен");
    return;
  }
 
  printf("Введите имя: ");
  gets(addr_list[slot].name);
 
  printf("Введите фамилию: ");
  gets(addr_list[slot].fam);
 
  printf("Введите отчество: ");
  gets(addr_list[slot].otch);
 
  printf("Введите должность: ");
  gets(addr_list[slot].dolg);
  
  printf("Дата рождения: ");
  gets(addr_list[slot].dat);
 
  printf("Месяц рождения: ");
  gets(addr_list[slot].mes);
 
  printf("Год рождения: ");
  gets(addr_list[slot].god);
}
 
/* Поиск свободной структуры. */
int find_free(void)
{
  int t;
 
  for(t=0; addr_list[t].name[0] && t<MAX; ++t) ;
 
  if(t==MAX) return -1; /* свободных структур нет */
  return t;
}
 
/* Удаление адреса. */
void remove(void)
{
 int slot;
  char s[80];
 
  printf("Введите № записи: ");
  gets(s);
  slot = atoi(s);
 
  if(slot>=0 && slot < MAX)
    addr_list[slot].name[0] = '\0';
}
 
/* Вывод списка на экран. */
void list(void)
{
  int t;
 
  for(t=0; t<MAX; ++t) {
    if(addr_list[t].name[0]) {
        printf(" Имя: %s\n",            addr_list[t].name);
        printf(" Фамилия: %s\n " ,      addr_list[t].fam);
        printf("Отчество: %s\n " ,      addr_list[t].otch);
        printf("Должность: %s\n ",      addr_list[t].dolg);
        printf("Дата рождения: %s\n ",  addr_list[t].dat); 
        printf("Месяц рождения: %s\n ", addr_list[t].mes);
        printf("Год рождения: %s\n ",   addr_list[t].god);
    }
  }
  printf("\n\n");
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru