Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Dikins
0 / 0 / 0
Регистрация: 28.12.2014
Сообщений: 2
#1

Среднее арифметическое главной и побочной диагоналей матрицы - C++

10.10.2015, 21:45. Просмотров 309. Ответов 1
Метки нет (Все метки)

Здравствуйте, помогите пожалуйста разобраться с ошибкой
В текстовом файле на первой строке расположены данные о размерности квадратной матрицы. Начиная со второй строки, расположена сама матрица. Не считывая матрицу в память, найти среднее арифметическое элементов главной и побочной диагонали, дописать найденные значения с пояснительной строкой в конец файла. Например, «Среднее арифметическое элементов главной диагонали - 127»

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
#include <cstdlib>
#include <iostream>
 
using namespace std;
 
int main()
{
 
    setlocale(LC_ALL, "Rus");
    FILE *f = fopen("matrix.txt", "r");
    if (f==NULL) 
    {
     printf("Файл не найден... /n Для окончания работы нажмите любую клавишу...");
     system("pause");
     exit(0);
    }
            
    int n, m;   // Razmernost`
    int i,j,a;
    int Smain=0; // Summa glavnoy
    int Ssec=0; //Summa pobochnoy
    float Smean, Gmean; //Pobochnaya i Glavnaya diagonali srednee znachenie
    
    fscanf(f, "%d%d", &n, &m); // Chitaem dannie iz faila  
    for (i = 0; i < n; i++)
    for (j = 0; j < m; j++)   // Glavnaya
    {   
        fscanf(f, "%d", &a);
        if(i==j) 
        {
           Smain+=a;
           Gmean+=Smain;   
        }
        Gmean/=m;
        }
        for (i = 0; i < n; i++) 
        for(j = 0; j < m; j++) // Pobochnaya
     {
        fscanf(f, "%d", &a);
        if(i+j==1+n)
        {
           Ssec+=a;
           Smean+=Ssec;     
        }
        Smean/=m;
    }
     fclose(f); 
     f = fopen("matrix.txt", "a");
     fprintf(f, "\n Mean main = %f;\n Mean secondary = %f;", Gmean, Smean);
     fclose(f);   
    system("PAUSE");
    return EXIT_SUCCESS;
}
Вообщем, ошибка в подсчёте побочной диагонали, всё время пишет одно и тоже значение, даже если меняю значения в матрице
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.10.2015, 21:45
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Среднее арифметическое главной и побочной диагоналей матрицы (C++):

Среднее арифметическое положительных элементов главной и побочной диагоналей матрицы - C++
Среднее арифметическое для главной,вроде,считает. Теперь нужно найти для побочной. Вопрос состоит в следующем,можно ли, не создавая...

Найти среднее арифметическое положительных элементов главной и побочной диагоналей матрицы - C++
Сразу скажу что не получается,не могу понять куда здесь впихивать условие проверки положительных чисел,и главное когда запускается студия...

Заменить элементы главной и побочной диагоналей матрицы на минимальный элемент ниже главной диагонали - C++
В квадратной матрице А заменить элементы главной и побочной диагоналей на минимальный элемент, найденный среди элементов, расположенных...

Вычислить среднее арифметическое побочной диагонали матрицы, и заменить им элементы ниже главной диагонали - C++
Вычислить среднее арифметическое элементов, находящихся на побочной диагонали двумерного массива и заменить результатом элементы,...

Транспонирование матрицы относительно главной и побочной диагоналей - C++
Подскажите как, транспонировать значения квадратной матрицы, относительно главной и побочной диагоналей.

Поменять местами элементы главной и побочной диагоналей матрицы - C++
помогите пожайлуста. Поменять местами элементы главной и побочной диагоналей матрицы. делал так, но не работает, просто выдаёт...

1
zss
Модератор
Эксперт С++
6691 / 6253 / 2084
Регистрация: 18.12.2011
Сообщений: 16,325
Завершенные тесты: 1
10.10.2015, 22:59 #2
C++
1
2
3
4
5
6
7
fseek(SET_SET,0);// перемотать файл на начало
     for (i = 0; i < n; i++) 
        for(j = 0; j < m; j++) // Pobochnaya
       {
           fscanf(f, "%d", &a);
           if(j==m-1-i)
                ...
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.10.2015, 22:59
Привет! Вот еще темы с ответами:

Переписать поочередно элементы главной и побочной диагоналей матрицы в массив - C++
вот сама задача: Переписать поочередно элементы главной и побочной диагоналей матрицы Аi,j в массив В

Найти максимальные элементы главной и побочной диагоналей матрицы и поменять их местами - C++
Дана матрица nxn. Найти максимальные элементы главной и побочной диагоналей матрицы и поменять их местами. Нашел максимальные элементы,...

Найти сумму элементов матрицы, лежащих выше главной и побочной диагоналей - C++
Универсальный алгоритм поиска элементов матрицы расположенных верхней половине матрицы без диагональных элементов исходя из ее размера...

Заполнить секторы матрицы лежащие влево и вправо от главной и побочной диагоналей - C++
Заполнить секторы матрицы А(9,9), которые лежат влево и вправо от главной и побочной диагоналей ЛП, от левого верхнего угла вправо - вниз....


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

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

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