Форум программистов, компьютерный форум CyberForum.ru

Помогите доделать программу. Поменять местами найденный максимальный элемент и значение S. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Матрица, рекурсия http://www.cyberforum.ru/cpp-beginners/thread1012340.html
Есть матрица 5х5. Состоит из 24-х нулей и одной единицы. Центр матрицы это элемент, позиция которого заходится в "координате" 3х3 (слева направо, сверху вниз, при условии, что матрица нумеруется с единицы). Необходимо подсчитать минимальное кол-во ходов, необходимых для того, чтобы единица(которая единственная в матрице) оказалась в центре матрицы. Единица может перемещаться за один ход только:...
C++ Сортировка матриц Слева-направо-вниз , от начала допомежной диагонали матрицы http://www.cyberforum.ru/cpp-beginners/thread1012319.html
Перестановка элементов матрицы C++
Перевернуть задом-наперёд элементы допомежной диагонали квадратной матрицы.
C++ Выборочная обработка матриц
Создать массив, элементы которого равны сумме элементов у парных рядках матрицы.
C++ Считать значение а, отобразить график f=x+a и пробежаться по нему точкой. http://www.cyberforum.ru/cpp-beginners/thread1012311.html
Прошу помочь, не знаю как написать программу на языке си или си плюс плюс!! Задача: считаешь значение а, отобразить график f=x+a и пробежаться по нему точкой. Кто чем может помочь?
C++ считывание дерева из файла Информация о файлах на жестких дисках компьютера записана с помощью дерева. Обеспечить выполнение следующих операций: 1) загрузку дерева в память из файла; 2) сохранение дерева в файле; 3) корректировку дерева при переименовании папок и файлов подробнее

Показать сообщение отдельно
rafael999
0 / 0 / 0
Регистрация: 14.09.2013
Сообщений: 148
19.11.2013, 19:36     Помогите доделать программу. Поменять местами найденный максимальный элемент и значение S.
Помогите пожалуйста разобраться с заданием , первые два у меня работают отлично , а вот третье в котором нужно вместо А[3][j_max] поставить сумму найденную в первом задании , возникает проблема.

Постановка задачи. Исходный массив считать из файла *.txt (файл создать самим). Результаты вычислений и манипуляций над массивом вывести на экран и в файлы*.xls. Для записи результатов в файл создать пользовательскую функцию.
Дана матрица А(4,4)
1.Найти сумму элементов среди элементов расположенных на главной диагонали матрицы А.
2.Найти максимальный элемент в 3-ей строке матрицы
3.Поменять местами найденный максимальный элемент и значение S.
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
71
72
73
74
75
76
77
78
79
80
81
82
#include"stdafx.h"
#include<iostream>
#include<iomanip>
#include<fstream>
#include<math.h>
using namespace std;
void read_matr(double Y[4][4]){
ifstream f("c://yes.txt");
for(int i=0; i<4; i++){
for(int j=0; j<4; j++){
f>>Y[i][j];}
 }
 f.close();}
void print_matr(double Y[4][4]){   //печатьматрицывконсоль
 cout<<"matrica:"<<endl;
for(int i=0; i<4; i++){
for(int j=0; j<4; j++){
cout<<setw(10)<<Y[i][j];}
 cout<<endl;}
 }
void print_values(char*str, double v){ // выводвфайлполученныхданных //(дляпунктов 1-4, 6)
fstream f1;
f1.open("values.xls", ios::app);
f1<<str<<"\t"<<v<<endl;
f1.close();
}
void print_matr_file(char*f_name, double Y[4][4]){// выводматрицыв //файлсименем f_name
ofstream f2(f_name);
for(int i=0; i<4; i++){
for(int j=0; j<4; j++){
f2<<Y[i][j]<<"\t";
}
f2<<endl;
}
f2.close();
f2.clear();}
 
double function1(double Y[4][4]){
double s=0;
for (int i = 0; i < 4; i++)
{s+=Y[i][i];
}
print_values("1)\tсумма элементов главной диагонали = ",s);
return s;
}
void function2(double Y[4][4]){
double max=-1000; int j_max;
for(int j=0; j<4; j++)
{
if(Y[2][j]>max){
max=Y[2][j];
j_max=j;}}
print_values("2)\tнаибольшийэлемент 3 строки = ",max);
print_values("\tномерстолбца = ",j_max+1);
cout<<" max = "<<max;
cout<<"; nomer stolbca = "<<j_max+1<<endl;
}
void function3(double Y[4][4], double ss){
Y[2][j_max]=ss;
print_matr(Y);
print_matr_file("3zadanie.xls",Y);
}
 
 
 
int main(){
double A[4][4];
 read_matr(A);
 cout<<"ishodnaja matrica:"<<endl;
 print_matr(A);
cout<<"vipolnenie:"<<endl;
// 1 - нахождение суммы всех элементов в матрице
double s1=function1(A);
cout<<"1) summa glavnoy diagomali = "<<s1<<endl;
// 2 - наибольший элемент вглавной диагонали
cout<<"2) naibolshii element v 3 stroke:"<<endl;
function2(A);
// 3 - поменять А[3][j_max] на s1
cout<<"3) pomenjat A[3][j_max] na s1"<<endl;
function3(A, s1);
return 0;
 }
Спасибо!
Миниатюры
Помогите доделать программу. Поменять местами найденный максимальный элемент и значение S.  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru