Есть структура, в которой хранится 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;
- Сохранение введенного идентификатора в структуре данных.}
- Конец блока кода.}
- Конец цикла.//...
- Возможно, есть еще код после этого, но он не виден в данном контексте. Пожалуйста, обратите внимание, что этот код не обрабатывает ошибки ввода или другие потенциальные проблемы, которые могут возникнуть во время его выполнения.
ИИ поможет Вам:
- решить любую задачу по программированию
- объяснить код
- расставить комментарии в коде
- и т.д