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

односвязный список с хэш таблицей

08.02.2014, 18:41. Показов 620. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть односвязный список успешности студентом
поля (фамилия,сер. бал,номер зачетки,группа)
как с этого намутить хэш таблицу ? помогите сделать
а то не понимаю саму суть хэш функции ((

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
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <iostream>
 
using namespace std;
 
class racer
{
 public:
  char name[128];
  int pos;
  int team;
  int group;
  racer *next;
} *head=NULL;
 
void print(racer *u)
{
   racer *p = u;
   cout << "Spisok:" << endl;
   while(p)
   {
     printf(" %d %s %d %d \n",p->pos,p->name,p->team,p->group);
      p = p->next;
   }
}
 
 
void addtail(racer **_head,int _pos, char *_name, int _team, int _group)
 {
  racer *new_racer= new racer;
  strcpy (new_racer->name,_name);
  new_racer->pos =_pos;
  new_racer->team=_team;
  new_racer->group=_group;
  if (*_head==NULL) {*_head = new_racer; new_racer->next=NULL;}
 else
 {
  racer *pfh=*_head;
  while(pfh->next) pfh=pfh->next;
  pfh->next=new_racer;
  new_racer->next=NULL;
 };
return;
}
 
 
void swap(racer** pH, racer *pfh)
 {
 
     racer *p2;
     racer *pPrev=*pH;
 
    if (pfh->next==NULL) return;
     else
    {
      p2=pfh->next;
      if (pfh==*pH) {*pH=p2;pfh->next=p2->next;p2->next=pfh;}
       else
        {
         while (pPrev->next!=pfh)  pPrev=pPrev->next;
         pPrev->next= p2;
         pfh->next = p2->next;
         p2->next = pfh;
        }
    }
 }
 
 void search(racer *u)
{   char k[128];   cout<<"enter surname for search";
cin>>k;
racer *m = u;
  while(m) {
    if(!strcmp(k,m->name)) cout<<" match found"<<"\n "<<m->name<<" "<<m->pos<<" "<<m->team<<" "<<m->group;
    m= m->next;
  }
   /* подходящий элемент не найден */
}
int main()
 {
  racer *Jh;
  racer *Ih;
  racer *Buf;
  char name[128];
  int pos,n=1,team,group;
 
   while (n==1)
   {
   printf("enter the data(surname - ser bal - # zalikovka - group )\n");
   scanf("%s %d %d %d",name,&pos,&team,&group);
    addtail(&head,pos,name,team,group);
    printf("for entering new student press 1 for exit 0\n");
    scanf("%d",&n);
   };
  getch();
  print(head);
 Ih=head;
 Jh=head;
 
 while (Ih->next)
 {    Jh=head;
          while(Jh->next)
                   if ((Jh==head)&&((Jh->pos)>(Jh->next->pos)))
                   {
                    swap(&head,Jh);
                    Jh=head->next;
                    if (Ih==Jh)
                    Ih->next=Jh;
                    if (Ih==Jh->next)
                    Ih=Jh;
                   }
                   else
                     if ((Jh->pos)>(Jh->next->pos))
                     {
                      swap(&head,Jh);
                      if (Ih==Jh) Ih->next=Jh;
                      if (Ih==Jh->next) Ih=Jh;
                     }
                   else  Jh=Jh->next;
  Ih=Ih->next;
 }
  print(head);
  search(head);
  getch();
 
  return 0;
 }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.02.2014, 18:41
Ответы с готовыми решениями:

Сформировать список из 10 книг, используя динамическую структуру данных односвязный список
друзья спасайте Сформировать список из 10 книг, используя динамическую структуру данных односвязный список С++

Создать класс «Квартира», в котором список комнат реализовать как односвязный список
Добрый день,написал фот такой клас по заданию:Создать класс «Квартира», в котором список комнат реализовать как односвязный список....

Заменить массив структур на односвязный список, и на двусвязный список
Взять текст задания и заменить массив структур на односвязный список, и на двусвязный список using namespace std; class person { ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.02.2014, 18:41
Помогаю со студенческими работами здесь

Создать двусвязный список групп факультета, где каждая группа представляет собой односвязный список студентов
Задание: создайте двусвязный список групп факультета. Каждая группа представляет собой односвязный список студентов. Помогите пожалуйста,...

Задали односвязный линейный список с целыми числами. Создать новый список, который содержит элементы заданного списка в обратном порядке
Задали односвязный линейный список с целыми числами. Создать новый список, который содержит элементы заданного списка в обратном порядке.

Преобразовать односвязный список в двусвязный список
Доброго времени суток! Помогите, пожалуйста, преобразовать программу из односвязного списка в двусвязный. Спасибо. #include...

Односвязный список
Здравствуйте,правильно ли организовал ввод #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; struct spisok { int info; spisok *link;...

Односвязный Список
Как реализовать список в этом коде, необязательно писать код буду благодарен за совет или подсказку! #include &quot;stdafx.h&quot; ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru