Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Rokil
0 / 0 / 0
Регистрация: 04.10.2013
Сообщений: 7
1

Если диагональный элемент отрицательный, то дописать его в конец файла

15.08.2014, 07:42. Просмотров 458. Ответов 1
Метки нет (Все метки)

Задание:Создать файл, содержащий матрицу действительных чисел A размерности n * n. Просмотреть элементы главной диагонали. Если диагональный элемент отрицательный, то дописать его в конец этого файла, а на его место записать 999.99. Вывести на экран информацию в виде: сначала напечатать замененные диагональные элементы, а затем - матрицу размерности n*n с замененными диагональными элементами. Определить и напечатать число компонентов в реорганизованном файле.

Не совсем понимаю как дописать отрицательный элемент в конец файла,и как вывести сначала заменённые диагональные элементы,а потом саму матрицу!
Заранее спасибо!

вот сам код:

C
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
void matrix(char name[40],int n, int m)
{
FILE * g = fopen("temp.dat","rb");
FILE * f= fopen(name,"wb");
rewind(f);
 
float **z;
z=new float*[n];
for (int i=0;i<n;i++)
z[i]=new float[m];
printf("\n");
for (int i=0;i<n;i++){
for (int j=0;j<m;j++){
fread (&z,sizeof(float),1,g);
if (i==j && z[i][j]<0){
fwrite(&z,sizeof(float),1,f);
printf ("%6.1", z[i][j]);
z[i][j]=999.9;}
fwrite (&z,sizeof(float),1,f);
printf ("%6.1f", z[i][j]);
}
printf ("\n");
}
}
 
int write(char name[40])
{
srand(time(NULL));
int n,m;
printf ("Введите размерность столбца: ");
scanf ("%d", &n);
printf ("Введите размерность строки: ");
scanf ("%d", &m);
FILE *f = fopen ("temp.dat","wb");
float **z;
z=new float*[n];
for (int i=0;i<n;i++)
z[i]=new float[m];
 
for (int i=0;i<n;i++){
for (int j=0;j<m;j++){
z[i][j]=rand()%31 - rand()%40/(1.+rand()%3);
printf ("%6.2f", z[i][j]);
fwrite (&z,sizeof(float),1,f);
}
printf("\n");
}
fclose(f);
matrix(name,n,m);
}
 
 
 
 
int main(int argc, char** argv) {
    system("chcp 1251");
    printf("Введите имя файла \n");
    char name[40];
    gets(name);
    write(name);
    return 0;
    system ("PAUSE");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.08.2014, 07:42
Ответы с готовыми решениями:

Если первый элемент строки больше некоторого заданного числа, то его следует поставить в конец строки
В матрице размером m x n для каждой строки матрицы сделать следующие действия:...

Найти наибольший отрицательный элемент массива А(23) и удалить его
Найти наибольший отрицательный элемент массива А(23) и удалить его.На языке Си

Вывести на экран первый отрицательный элемент массива (одномерного) и его номер
Я немного туплю с Си и не шибко представляю суть программы, если кто нибудь...

Перенести в конец непустого списка L его первый элемент
Написать процедуру, которая переносит в конец непустого списка L его первый...

Проверить, все ли строки матрицы содержат хотя бы один отрицательный элемент Если да, то изменить знаки всех элементов м
Проверить, все ли строки матрицы содержат хотя бы один отрицательный элемент...

1
Vtulhu
423 / 377 / 200
Регистрация: 12.08.2011
Сообщений: 1,610
15.08.2014, 12:13 2
Разбейте программу на меньшие части, невозможно читать. Отдельно создание матрицы, отдельно запись в файл...
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.08.2014, 12:13

Найти в каждой строке матрицы, если там есть отрицательный элемент, ср. арифметическое всех элементов, исключая нулевые
Задана матрица Z(5,4) Найти в каждой строке, если там есть отрицательный...

Если в массиве присутствует заданное значение - удалить его, иначе добавить в конец массива
Определить, есть ли в целочисленном массиве Q(10) заданное число Х, и если...

Матрица. Поменять наибольший элемент и диагональный элемент.
Дана целочисленная квадратная матрица. Найти в каждой строке наибольший...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru