ВУЗ: Не указан

Категория: Не указан

Дисциплина: Не указана

Добавлен: 19.08.2024

Просмотров: 12

Скачиваний: 0

ВНИМАНИЕ! Если данный файл нарушает Ваши авторские права, то обязательно сообщите нам.

Технологія створення програм

Лабораторна робота №4_2

Дана лабораторна робота має бути виконана групою студентів. Група студентів отримує загальне завдання, яке є сукупністю підзадач-модулів. Кожен студент є членом команди і виконуює одне із завдань. Один з членів групи, будучи керівником проекту, здійснює керівництво проекту (визначає складність завдань, розподіляє роботу і конролирует процес її виконання).

Результатом роботи групи є програма, що складається з окремих модулів, що мають загальний інтерфейс.

Керівник проекту контролює процес виконання роботи, написання звіту і представляє роботу викладачеві, дає оцінку роботи кожного члена команди.

Лабораторна робота розрахована на 6 годин виконання:

1 Заняття (2 години):

  • видача індивідуальних завдань;

  • розробка плану виконання робіт групою (розподіл ролей в команді, розподіл завдань, розробка єдиного інтерфейсу);

  • розробка алгоритмів, написання код кожним членом команди.

2 Заняття (2 години):

  • тестування код;

  • написання звітів-інструкцій;

  • вироблення одного загального звіту.

3 Заняття (2 години):

  • захист лабораторної роботи (виконується керівником групи);

  • оцінка вкладу кожного члена команди.

Звіт повинен містити:

  1. Тему і мету лабораторної роботи;

  2. Блок-схему алгоритму;

  3. Коди кожного завдання;

  4. Інструкцію по роботі.

Тема: Файли.

Операции с текстовыми файлами

Запис даних у файл

Описати покажчик на файл                                                                                                

FILE *filename;

1.      Відкрити файл (функція fopen)

Опис функції

FILE *fopen(const *filename, const char *mode)

filename – рядок, в якому зберігається повне ім'я файлу, що відкривається.

mode – рядок, який визначає режим роботи з файлом; можливі наступні значення:

«r» – відкриваємо текстовий файл в режимі читання;

 «w» – створюємо текстовий файл;

 «a» – створюємо або відкриваємо текстовий файл для дозапису в кінець файлу;

 «r+» – відкриваємо текстовий файл в режимі читання і запису;


 «w+» – відкриваємо текстовий файл для виправлення, старий вміст викидається;

 «a+» текстовий файл відкривається або створюється для виправлення існуючої інформації і додавання новою в кінець файлу;

Функція повертає покажчик на файлову змінну або NULL при невдалому відкритті файлу.

2.      Записати даних у файл (функція fprintf )

Функція fprintf аналогічна функції printf, єдиною відмінністю є перший параметр – покажчик на файл. За допомогою цієї функції вивід здійснюється не на екран, а на файл.

3.      Закрити файл (функція fclose )

int fclose(FILE *filename);

Повертає 0 при успішному закритті файлу і NULL інакше.

Окрім цих функцій для роботи з файлами є ще дві:

 

int remove(const char *filename);

Ця функція видаляє з диска файл, покажчик на який зберігається у файловій змінній filename. Функція повертає ненульове значення, якщо файл не удалося видалити.

int rename(const char *oldfilename, const char *newfilename);

Функція перейменовує файл; перший параметр – старе ім'я файлу, другий – нове. Повертає 0 при невдалому завершенні програми.

 

Читання даних з файлу

 

1.      Описати покажчик на файл

FILE *filename;

2.      Відкрити файл (функція fopen)

3.      Рахувати дані з файлу (функція fscanf)

Функція fscanf аналогічна функції scanf, єдиною відмінністю є перший параметр – покажчик на файл. За допомогою цієї функції вивід здійснюється не на екран, а на файл.

4.      Закрити файл (функція fclose )

Приклад1.  У файлі abc.txt зберігаються матриці A(N,M) і B(M,K). Хай структура файлу наступна: у першому рядку зберігаються числа n і m, потім відрядковий матриця A, за тим рядок, в якому зберігається m і до. Потім – відрядковий матриця B. Знайти матрицю С=a.B і записати її у файл rez.txt.

#include <stdio.h>

#include <math.h>

#include <stdlib.h>

#include <alloc.h>

int main()

{

int i,j,n,m,l,k;

float *b,*c,*a,s,temp;

FILE *f;

f=fopen("abc.txt","r");

fscanf(f,"%d%d",&n,&m);

a=(float *)

calloc(n*m,sizeof(float));

for(i=0;i<n;i++)

for(j=0;j<m;j++)

{

fscanf(f,"%g",&temp);

*(a+i*m+j)=temp;

}

fscanf(f,"%d%d",&m,&l);

b=(float *)calloc(m*l,sizeof(float));

c=(float *)calloc(n*l,sizeof(float));

for(i=0;i<m;i++)

for(j=0;j<l;j++)

{

fscanf(f,"%g",&temp);


*(b+i*l+j)=temp;

}

fclose(f);

f=fopen("rez.txt","w");

for(i=0;i<n;i++)

for(j=0;j<l;*(c+i*l+j)=s,j++)

for(s=0,k=0;k<m;k++)

s+=*(a+i*m+k)**(b+k*l+j);

fprintf(f,"Њ ваЁж  C\n");

for(i=0;i<n;i++)

{

for(j=0;j<l;j++)

fprintf(f,"%g\t",*(c+i*l+j));

fprintf(f,"\n");

}

fclose(f);

free(a);

free(b);

free(c);

}

Контрольне питання

 У текстовому файлі f.txt записані (упереміш) цілі числа: порівну негативних і позитивних. Використовуючи лише один допоміжний файл, переписати в текстовий файл h.txt всі ці числа так, щоб:

  1. порядок негативних чисел був збережений;

  2. порядок позитивних чисел був збережений;

  3. будь-які два числа, що стоять поряд, мали різні знаки.

1

  • Заповнити файл послідовного доступу f цілими числами, отриманими за допомогою генератора випадкових чисел. Отримати у файлі g ті компоненты файлу f, які є парними.

  • Записати у файл послідовного доступу N дійсних чисел. Обчислити твір компонентів файлу і вивести на друк.

  • Заповнити файл послідовного доступу f цілими числами, отриманими за допомогою генератора випадкових чисел. Отримати у файлі g всі компоненты файлу f, які діляться на т і не діляться на п.

  • Записати у файл послідовного доступу N цілих чисел, отриманих за допомогою генератора випадкових чисел. Підрахувати кількість пар протилежних чисел серед компонентів цього файлу.

2

  • Заповнити файл послідовного доступу f цілими числами, отриманими за допомогою генератора випадкових чисел. З файлу f отримати файл g, виключивши повторні входження чисел. Вивести файл g на друк.

  • Заповнити файл послідовного доступу N дійсними числами, отриманими за допомогою датчика випадкових чисел. Знайти суму мінімального і максимального елементів цього файлу.

  • Записати у файл послідовного доступу N натуральних чисел: a1, a2..., an (числа отримати за допомогою генератора випадкових чисел). Сформувати новий файл послідовного доступу, елементами якого є числа а1, а1•а2, а1•а2•а3..., al•a2•a3•...•an.

  • Записати у файл f послідовного доступу N натуральних чисел. Отримати в іншому файлі послідовного доступу всі компоненты файлу f, окрім тих, які кратні K. Вивести отриманий файл на друк.

3

  • Заповнити файл f натуральними числами, отриманими за допомогою генератора випадкових чисел. Знайти кількість квадратів непарних чисел серед компонентів.

  • Записати у файл прямого доступу N дійсних чисел. Знайти найбільше із значень модулів компонентів з непарними номерами.

  • Заповнити файл f цілими числами, отриманими за допомогою генератора випадкових чисел. З файлу f отримати файл g, виключивши повторні входження чисел. Порядок дотримання чисел зберегти.

  • Записати у файл послідовного доступу N дійсних чисел. Знайти різницю першого і останнього компонентів файлу.


4

  • Записати у файл f N цілих чисел, отриманих за допомогою генератора випадкових чисел. Заповнити файл g числами, які є творами сусідніх компонентів файлу f.

  • 16. Записати у файл послідовного доступу п елементів послідовності 

  • . Вивести на друк ті компоненты файлу, для яких виконується |bn| > ?, де ? — задане число.

  • 17. Записати у файл послідовного доступу N дійсних чисел а1, а2 ..., an. Організувати новий файл послідовного доступу, елементи якого обчислюються за формулою 

  • . Вивести отриманий файл на друк.

6