Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 01.04.2013
Сообщений: 49

Реализация с односвязным списком

14.10.2014, 00:14. Показов 639. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую! Есть созданная программа:
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
#include <iostream>
#include <fstream>
#include <clocale>
#include <string.h>
#include <stdlib.h>
using namespace std;
struct podrazdelenie
{
    char fio[100], otdel[30];
};
int main()
{
    setlocale(LC_ALL,"Russian");
    char otd[][12] = {"отделкадров", "приемная" ,"менеджер", "замдиректор", "инженер", "конструктор"};
    podrazdelenie obj[100];
    int i=0;
    ifstream f("D://company.txt");
    char bufstr[1001];
    int ii=0;
    bool flag = true;
    while (f.good())
    {
        char* tmp = new char [100];
        f>>tmp>>tmp>>obj[ii].fio>>tmp>>tmp>>tmp>>tmp>>obj[ii++].otdel;
        f.getline(bufstr,100);
        if (flag)
        {
            flag = false;
            ii--;
        }
    }
    f.close();
    char ot[12]={0};
    int kol=0,buf=0;
    for (int j=0; j<ii; j++)
    {
        for (int k=0; k<ii; k++)
            if(strstr(obj[k].otdel, otd[j]))
                buf++;
        if (buf>kol)
        {
            kol=buf;
            strcpy(ot,otd[j]);
        }
        buf=0;
    }
    cout<<"Лучшим подразделением есть "<< "'"<< ot <<"'"<<  " c " << kol << " сотрудниками "<<'\n';
    system("pause");
    return 0;
}
То есть она считывает с файла company.txt company.txt перечень всех отделов и подсчитывает количество по отделам сотрудников.
Нужно бы ее перекодировать под реализацию с односвязными списками. Что подскажите?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.10.2014, 00:14
Ответы с готовыми решениями:

Работа с односвязным списком
Дан односвязный список. Класс студент (фамилия группа). Сделать меню, т.е. удаление элемента из начала списка, добавление элемента в начало...

Работа с односвязным списком
Есть два вопроса 1)как найти сумму двух соседних элементов элемента x. 2)Как сделать чтоб функция RemovePositive удаляла все...

Задачка с односвязным списком
Не могу разобраться с вставлением элементов из массива в список и рекурсивной функцией. Надеюсь кто-то поможет) спасибо) Нужно написать...

1
0 / 0 / 1
Регистрация: 01.04.2013
Сообщений: 49
15.10.2014, 10:23  [ТС]
Здравствуйте! я уже практически все сам сделал.Вот мой новый код:
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
#include <iostream>
#include <fstream>
#include <conio.h>
#include <stdlib.h>
using namespace std;
 
struct COMPANY {
  char Unity [30];
  int Number ;
  int profit;
  COMPANY *prev;
 COMPANY *next;
};
 
COMPANY *first = NULL;
COMPANY *last = NULL;
 
 
void Search (void);
int Print (void);
int Menu (void);
 
int main (void)
{
    while (Menu ());
    return 0;
}
void Add (COMPANY *company)
{
  if (last != NULL)
  {
    company->prev = last;
    company->next = NULL;
    last->next = company;
    last = company;
  }
  else
  {
    company->prev = NULL;
    company->next = NULL;
    first = company;
    last = company;
  }
}
void AddItem (void)
{
  COMPANY *company;
  company = new COMPANY;
  cout << "Vvedite naimenovanie podrazdeleniya: ";
  cin >> company->Unity;
  cout << "Vvedite kolichestvo sotrudnikov: ";
  cin >> company->Number;
  cout << "Vvedite poluchennuyu pribyl: ";
  cin >> company->profit;
  Add (company);
}
 
void Search (void)
{
  COMPANY *company = first;
  int b=Number[i];
    for(int i;;i++)
  {
    if (b>Number[i+1])
    {
        b=Number[i+1];
    }
     }
  cout << "Luchshim otdelom est':" << company->Unity<< " s " << b << "sotrudnikami" << endl;
 }
int Print (void)
{
  COMPANY *company = first;
  int i = 0;
 
  cout << endl << "Predpriyatie imeet:" << endl;
  while (company)
  {
    i++;
    cout << i << ". otdel: " << company->Unity << "; kolichestto sotrudnikov: " << company->Number << "; oklad: " << company->profit << endl;
    company = company->next;
  }
  return i;
}
 
int Menu (void)
{
  char ch = 0;
 
  cout << "\nVash vybor:" << endl;
  cout << "1. Dobavit' v spisok." << endl;
  cout << "2. Pechat' spiska." << endl;
  cout << "3. Poisk v spiske." << endl;
  cout << "4. Vyhod." << endl;
 
  while (ch < '1' || ch > '6')
  {
    ch = getch ();
  }
 
   switch (ch)
  {
 
    case '1': AddItem (); break;
    case '2': Print (); break;
   case '3': Search (); break;
    case '4': return 0;
  };
  return 1;
}
осталось только мелочь: это сформированном списке найти лучший отдел по количеству сотрудников. То есть я хотел сначала сравнить все количества сотрудников по отделам, а потом уже исходя из этого лучшего числа указать на соответствующий отдел. Если поможете в этом маленьком деле, буду очень Вам благодарен!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.10.2014, 10:23
Помогаю со студенческими работами здесь

Задача с односвязным списком
Ребята, нужна помощь, кто может составьте. Буду благодерен. У меня не получается, т.к руки кривые. Задача: Напишите программу,...

Класс полином с односвязным списком
Помогите,пожалуйста, Написал класс Полином с односвязным списком,нужно создать функции,первая,которая считает результат полинома в данной...

Работа с односвязным линейным списком
Здравствуйте, нужна ваша помощь , нужно програмка для работы с односвязным линейным списком а именно создание,удаление и поиск по значению...

Полиморфизм в сочетании с односвязным списком
Всем доброго времени суток!) В общем, появилась такая проблема: нужно реализовать полиморфизм, при этом используя односвязный список,...

Ошибки связанные с односвязным списком
Здравствуйте... Решила сама разобраться и написать программу, связанную с работой с односвязным списком. Для красоты решила оформить каждое...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru