Есть структура, в которой хранится ID, фио пациента. Но ID я могу заводить одинаковые - C (СИ)
Формулировка задачи:
Подскажите пожалуйста, как лучше сделать так, чтобы ID были уникальными.
#include <stdio.h> #include <string.h> typedef struct{ int id; char famil[20]; char imya[20]; char otchest[20]; char adres[20]; int phone; int nomer; char diagnoz[30]; } Patient; Patient a[100]; int function () //проверка на корректность целого числа { char s[100]; while (1 > 0) { int len, point = 0, simbol = 0, i = 0; scanf ("%s", s); if (s[0] == '-') i++, simbol++; len = strlen(s); for (; i < len; i++) { if (isdigit(s[i])) simbol++; if (s[i] == '.') point++; } if (simbol == (len - point)) break; printf("Poproby snova!\n"); } return(atoi(s)); } int fun (int a, int b)//функция, возвращающая переменную вещественного типа и непринимающая аргументов { int flag = 0; char s[100];//объявление строки while (1 > 0)//бесконечный цикл, который не прервется, пока не будет введено верное значение { flag = 0; int len, i = 0;//объявление переменных целочисленного типа scanf ("%s", s);//ввод строки с клавиатуры len = strlen(s);//присваивание переменной значения длины введенной строки for (; i < len; i++)//цикл, проходящий по всем символам введенной строки { if (isdigit(s[i]) == 0) { flag = 1; //проверяем флаг потом во внешнем цикле break; } } if (((atoi(s) > a) && (atoi(s) < b) || (flag == 1))) return(atoi(s)); else printf("Poproby snova!\n"); continue;//продолжение цикла в случае не выполнения условия на числовое значение } } void cozdatZapisi() { fflush(stdin); int z, i; printf("Vvedite chislo patient: "); z= function(); for(i=0;i<z;i++){ printf("%d", i+1); printf("\n Vvedite id: "); a[i].id= function(); while(1){ printf(" Vvedite famil: "); scanf("%s", &a[i].famil); if(strtol(a[i].famil, NULL, 10)==0) break; printf("Poproby snova!\n"); } while(1){ printf(" Vvedite imya: "); scanf("%s", &a[i].imya); if(strtol(a[i].imya, NULL, 10)==0) break; printf("Poproby snova!\n"); } while(1){ printf(" Vvedite otcest: "); scanf("%s", &a[i].otchest); if(strtol(a[i].otchest, NULL, 10)==0) break; printf("Poproby snova!\n"); } while(1){ printf(" Vvedite adres: "); scanf("%s", &a[i].adres); if(strtol(a[i].adres, NULL, 10)==0) break; printf("Poproby snova!\n"); } printf(" Vvedite nomer med. karti: "); a[i].nomer= function(); while(1){ printf(" Vvedite diagnoz: "); scanf("%s", &a[i].diagnoz); if(strtol(a[i].diagnoz, NULL, 10)==0) break; printf("POPROBY SNOVA!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n"); } printf("\n"); fflush(stdin); } } int main() { int n; while(1) { char control; printf( "1 - Cozdat baza patient\n" "2 - Spisok patientov po diagnoz\n" "3 - Spisok patientov po nomer\n" "0 - Exit\n"); scanf("%c", &control); fflush(stdin); switch (control) { case '1': { cozdatZapisi(); break; } case '2': { char b[100]; int i; printf("Diagnoz: "); scanf("%s", &b); int flag1 = 0; for(i=0; i<100; i++){ if(strcmp(a[i].diagnoz, b)==0){ printf("FIO patient: %s %s %s\n", a[i].famil, a[i].imya, a[i].otchest); flag1 = 1; } if (flag1 == 0)printf("Net patient s takim diagnoz\n"); break; } getchar(); getchar(); fflush(stdin); break; } case '3': { char b[100]; int g, o; int i; int flag1 = 0; printf("Zadaite nomer 1: "); scanf("%i", &g); printf("Zadaite nomer 2: "); scanf("%i", &o); for(i=0; i<100; i++){ if(g<a[i].nomer && a[i].nomer <o){ printf("FIO i nomer patient: %s %s %s %i\n", a[i].famil, a[i].imya, a[i].otchest, a[i].nomer); flag1 = 1; } if (flag1 == 0)printf("Net patient\n"); break; } getchar(); getchar(); fflush(stdin); break; } case '0': { return 0; } default: break; } } return 0; }
Решение задачи: «Есть структура, в которой хранится ID, фио пациента. Но ID я могу заводить одинаковые»
textual
Листинг программы
//... printf("\n Vvedite id: "); while(true){ int id = function();//ввод числа bool is_ok = true; for(int j=0;j<i;j++){ if (a[j].id==id) { is_ok = false; break; } } if (is_ok){ break; } printf("Poproby snova!\n"); } a[i].id=id; //...
Объяснение кода листинга программы
В этом коде представлен ввод уникального идентификатора (id) для структуры данных, содержащей информацию о пациентах. Предполагается, что идентификаторы должны быть уникальными, и код проверяет это, проходя циклом по уже введенным идентификаторам. Если такой же идентификатор уже существует, пользователю предлагается ввести другой. Когда введен уникальный идентификатор, он сохраняется в структуре данных. Вот список элементов кода с номерами:
printf(
\n Vvedite id:);
- Вывод приглашения для ввода идентификатора.while(true){
- Начало бесконечного цикла.int id = function();//ввод числа
- Ввод идентификатора с помощью функции ввода.bool is_ok = true;
- Объявление переменной для проверки уникальности идентификатора.for(int j=0;j<i;j++){
- Цикл для проверки уникальности введенного идентификатора.if (a[j].id==id) {
- Проверка наличия идентификатора в массиве структур.is_ok = false;
- Если идентификатор уже существует, переменная проверки становится ложной.break;
- Выход из цикла, если идентификатор уже существует.if (is_ok){
- Проверка, является ли идентификатор уникальным.break;
- Выход из цикла, если идентификатор уникален.printf(
Poproby snova!\n);
- Вывод сообщения об ошибке, если идентификатор не уникален.a[i].id=id;
- Сохранение введенного идентификатора в структуре данных.}
- Конец блока кода.}
- Конец цикла.//...
- Возможно, есть еще код после этого, но он не виден в данном контексте. Пожалуйста, обратите внимание, что этот код не обрабатывает ошибки ввода или другие потенциальные проблемы, которые могут возникнуть во время его выполнения.
ИИ поможет Вам:
- решить любую задачу по программированию
- объяснить код
- расставить комментарии в коде
- и т.д