pragma hdrstop pragma argsused include stdio include conio include win

  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
#pragma hdrstop
#pragma argsused
#include <stdio.h>
#include <conio.h>
#include <windows.h>
#include <string.h>
struct Exams {
char FamIO[30];
int Ball;
};
struct Telem{
Exams inf;
Telem *next;
} *begD;
void createStack(FILE *inputFile){
Telem *p = new Telem;
Telem *help1 = begD;
Telem *help2;
fscanf(inputFile, "%s", &p -> inf.FamIO);
fscanf(inputFile, "%d", &p -> inf.Ball);
if (begD) { //есть ли стек
if ((p->inf.Ball)<=(help1->inf.Ball)) { //сравнение
while ((p->inf.Ball)<=(help1->inf.Ball)) { //пока подходит
if (help1->next!=NULL) { //есть ли след элемент
if ((p->inf.Ball)==((help1->next)->inf.Ball)){
while ((strcmp((p->inf.FamIO),((help1->next)->inf.FamIO))>0) && (p->inf.Ball)==((help1->next)->inf.Ball)) {
if (help1->next==NULL) {
help1->next=p; //если след элемента нет то текущий - последний
p->next=NULL;
return;
}
help1=help1->next;
}
p->next=help1->next; //вставляем элемент между ними
help1->next=p;
return;
}
if ((p->inf.Ball)>((help1->next)->inf.Ball)) { //если след балл больше
p->next=help1->next; //вставляем элемент между ними
help1->next=p;
return;
}
}
if ((help1->next==NULL)) {
if ((p->inf.Ball)==(help1->inf.Ball)){
while ((strcmp((p->inf.FamIO),(help1->inf.FamIO))>0) && (p->inf.Ball)==(help1->inf.Ball)) { printf("qq");
if (help1->next==NULL) {
help1->next=p; //если след элемента нет то текущий - последний
p->next=NULL;
return;
}
help1=help1->next;
}
p->next=help1->next; //вставляем элемент между ними
help1->next=p;
printf("qq");
return;
}
help1->next=p; //если след элемента нет то текущий - последний
p->next=NULL;
return;
}
help1=help1->next; //берём след элемент
}
help1->next=p; //условия перестали подходить значит элемент последний
p->next=NULL;
return;
}
else{
p->next=begD; // если 1 элемент уже не подошёл
begD=p;
return;
}
}
else{
p->next=NULL; //Убираем ссылку на следующий
begD = p; //Делаем новый элемент началом
}
};
//Печать дека на экран
void printStack(){
Telem *p; //Объявление нового элемента
p=begD; //Выделение элемента
printf("\nДек имеет вид: ");
while(p!=NULL)
{ printf("\n");
printf("%s ",p->inf.FamIO); //Выводим элемент
printf("%d ",p->inf.Ball);
if(p->next==NULL) { //если ссылки на следующий элемент нет, то выходим
break;
}
p=p->next;
}
printf("\n");
return;
};
int main()
{ SetConsoleOutputCP(1251);
SetConsoleCP(1251);
FILE* inputFile; //объявляем указатель на входной файл
inputFile=fopen("input.txt", "r"); //открываем текстовый файл для чтения
//если входной файл не открыт, выводим сообщение и выходим из программы
if (inputFile == NULL) {
printf("Can't open input.txt\n");
fclose(inputFile);
system("pause");
return 0;
}
begD = NULL;
while (!feof(inputFile)){
createStack(inputFile);
printStack();
}
system("pause");
return 0;
}