Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Массивы структур,срочно помощь  (Прочитано 3531 раз)
0 Пользователей и 1 Гость смотрят эту тему.
snegok1233
Читатель

ua
Offline Offline

« : 09-12-2013 20:57 » 

Нужна помощь вот задание:1  и 2 пункты сделал не могу разобраться с 3 и 4 пунктами (
Программа должна иметь следующее меню:
1.Вывод списка сотрудников
2.Редактирование
Добавление сотрудника
Удаление сотрудника

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



Код: (C++)
[color=black]#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");
}[/color]
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 09-12-2013 21:01 » new

Для простоты понимания сперва записывай алгоритм по шагам простыми словами.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines