Семинар 3 вариант 23
Описание файла
Документ из архива "Семинар 3 вариант 23", который расположен в категории "". Всё это находится в предмете "программирование и алгоритмизация" из 2 семестр, которые можно найти в файловом архиве НИУ «МЭИ» . Не смотря на прямую связь этого архива с НИУ «МЭИ» , его также можно найти и в других разделах. .
Онлайн просмотр документа "Семинар 3 вариант 23"
Текст из документа "Семинар 3 вариант 23"
Файлы в Си
Обработка данных сложной структуры, хранящихся в файлах
Вариант 23
Сведения о магазинах города состоят из названия, района, адреса, часов
работы. Вывести сведения о книжных магазинах данного района, работающих после 18 ч, и количество таких магазинов.
Решение
Пример входных данных представлен ниже.
Рис. 1. Пример входных данных
Пример решения программы представлен ниже на рисунке 2.
Рис. 2. Пример решения задания
Рис. 3. Пример выходных данных
Листинг программ представлен ниже.
Переменная-строка.
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <locale.h>
#define NMAX 60
int main()
{
setlocale(LC_ALL, "Rus");
char s[NMAX];
int i, j;
float ma = 0;
int n = 0;
for (i=0; i<NMAX; i++)
s[i]=' ';
FILE *f_in, *f_out;
f_in=fopen("Magaz.txt", "rt");
if (f_in==NULL)
puts("file is not opened");
else
if feof(f_in)
puts("file is empty");
else
{
f_out=fopen("Result.txt", "wt");
while (fgets(s,NMAX+1,f_in)!=NULL)
{
if (strstr(s,"Кузьминки")!=NULL)
for (i=NMAX-1; i>=0; i--)
if ((int)(s[i])>=48 && (int)(s[i]<=57))
{
if (((int)(s[i-1])==49 && (int)(s[i]==48))||((int)(s[i-1])>57 || (int)(s[i-1]<48)))
{
for (j = 0; j < NMAX; j++)
printf ("%c", s[j]);
printf ("\n");
fputs(s,f_out);
for (j = 0; j< NMAX; j++)
if ((int)(s[j])>=48 && (int)(s[j]<=57))
{
if ((int)(s[j+1])>=48 && (int)(s[j+1]<=57))
ma = ma + 10*((int)(s[j]) - 48) + ((int)(s[j+1]) - 48);
else
ma = ma + ((int)(s[j]) - 48);
n = n + 1;
break;
}
}
break;
}
for (i=0; i<NMAX; i++)
s[i]=' ';
}
}
fclose(f_out);
printf ("Average age: %2.2f\n", ma/n);
getch();
return 0;
}
Переменная-структура.
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <locale.h>
#define NMAX 20
int main()
{
typedef struct
{
char s1[NMAX],s2[NMAX],s3[NMAX];
int s4;
char s5[NMAX],s6[NMAX];
int s7;
}
fam_im;
fam_im f_i;
setlocale(LC_ALL, "Rus");
int i;
float ma = 0;
int n = 0;
FILE *f_in, *f_out;
f_in = fopen("Cats.txt", "rt");
if (f_in == NULL)
puts("file is not opened");
else
if feof(f_in)
puts("file is empty");
else
{
f_out = fopen("f_out.txt", "wt");
while (fscanf(f_in,"%s %s %s %d %s %s %d", &f_i.s1, &f_i.s2, &f_i.s3, &f_i.s4, &f_i.s5, &f_i.s6, &f_i.s7) != EOF)
if (strcmp(f_i.s1,"сиамская") == 0)
if (f_i.s7 <= 10)
{
fprintf(f_out, "%s %s %s %d %s %s %d\n", f_i.s1, f_i.s2, f_i.s3, f_i.s4, f_i.s5, f_i.s6, f_i.s7);
printf("%s %s %s %d %s %s %d\n", f_i.s1, f_i.s2, f_i.s3, f_i.s4, f_i.s5, f_i.s6, f_i.s7);
ma = ma + f_i.s4;
n = n + 1;
}
}
printf("\nAverage age: %2.2f\n", ma/n);
_getch();
return 0;
}
7