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

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

Войти
Регистрация
Восстановить пароль
 
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
#1

Функции: найти строку, которая имеет максимальную сумму элементов - C++

22.12.2010, 20:10. Просмотров 923. Ответов 11
Метки нет (Все метки)

Для даной программы нада дописать функцию суммы, Есть двухмерный массив , и нада найти строку , которая имеет максимальную сумму элементов.



Прозьба код программы не менять.

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
#include <iostream.h>
 
const int n=3,m=4;
void InArray ( float a[n][m]);
void PrintArray ( float a[n][m]);
void SumMax (float a[n][m]);
void main()
{
 float a[n][m];
 InArray (a);
 PrintArray (a);
 SumMax (a);
 }
void InArray (float a[n][m])
 
 {
 
   cout<<"ведите масив "<<n<<"*"<<m<<endl;
   for (int i=0;i<n;i++)
{
  for(int j=0;j<m;j++)
  cin>>a[i][j];
  cout<<endl;
} 
   }
    
    
void PrintArray ( float a[n][m])
 {
     cout<<"Матрица: \n ";
 for(int i=0;i<n;i++)
  {
    cout<<endl;
    for(int j=0;j<m;j++)
    cout<<"  "<<a[i][j];
    }
    }
 
    void SumMax (float a[n][m])
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.12.2010, 20:10
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Функции: найти строку, которая имеет максимальную сумму элементов (C++):

Дан двумерный массив.посчитать сумму элементов в кажой строке. найти максимальную и минимальную сумму и помень эти строки местами. - C++
Дан двумерный массив.посчитать сумму элементов в кажой строке. найти максимальную и минимальную сумму и помень эти строки местами. Я...

Найти максимальную сумму элементов на ярусе дерева - C++
Найти максимальную сумму элементов на ярусе дерева

Найти максимальную сумму элементов строки матрицы - C++
Данный двумерный массив. найти: а) максимальную сумму элементов строки; б) минимальную сумму элементов столбца

Найти максимальную сумму значений элементов строки в массиве - C++
#define _CRT_SECURE_NO_WARNINGS #define _CRT_NONSTDC_NO_WARNINGS #include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; ...

Действие с матрицей (Найти наименьшее из значений элементов столбца, который имеет наибольшую сумму модулей элементов) - C++
Заданная квадратная матрица целых чисел размерности n * n. Найти наименьшее из значений элементов столбца, который имеет наибольшую сумму...

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

11
Kostyanych77
172 / 11 / 2
Регистрация: 21.12.2010
Сообщений: 66
22.12.2010, 21:00 #2
вот добавь это:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
    float sumM=0,sumS=0;int st;
    for(int i=0;i<=n;++i)
    {
        for(int j=0;j<=m;++j)
            sumS+=a[i][j];
        if(sumM<sumS)
        {
            sumM=sumS;
            st=i;
        }
    }
    cout<<endl<<"Строка с максимальной суммай элементов: "<<st+1;
}
0
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
22.12.2010, 21:10  [ТС] #3
Цитата Сообщение от Kostyanych77 Посмотреть сообщение
вот добавь это:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
    float sumM=0,sumS=0;int st;
    for(int i=0;i<=n;++i)
    {
        for(int j=0;j<=m;++j)
            sumS+=a[i][j];
        if(sumM<sumS)
        {
            sumM=sumS;
            st=i;
        }
    }
    cout<<endl<<"Строка с максимальной суммай элементов: "<<st+1;
}

Тока мне считает элементы ))))) а мне нада сумму элементов )))
0
Kostyanych77
172 / 11 / 2
Регистрация: 21.12.2010
Сообщений: 66
22.12.2010, 21:14 #4
Тебе нужно чтоб выводило сумму или строку с максимальной суммой?
P.S. эта функция выводит строку с максимальной суммой, если чё могу переделать...
0
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
22.12.2010, 21:19  [ТС] #5
Нада найти в матрице , номер строки , имеющей максимальную сумму элементов.

вот так: массив

1 2 3 4
4 5 6 6
1 1 1 1
1 2 2 3

вот в строке 4 5 6 6 , сумма ровна 21 , тоесть мне номер строки и сумму элементов той строки.


Прикол в том что даже , когда уже прога посчитала , то строка с максимальной сумой ровна 4. Ни больше ни меньше , это если строка состоит из 4 элементов.
0
murod
-2 / 7 / 2
Регистрация: 04.11.2010
Сообщений: 163
22.12.2010, 21:20 #6
решение этой задачи:

#include <iostream>

using namespace std;

int sum(int n, int m)
{
double sum1 = 0, sum = 0, b[101];
int i, j, p = 1;
double a[101][101];
for(i = 1; i <= n; i++)
for(j = 1; j <= m; j++)
cin >> a[i][j];
for(j = 1; j <= m; j++)
b[1] += a[1][j];

for(i = 2; i <= n; i++)
for(j = 1; j <= m; j++)
b[i] += a[i][j];

for(i = 2; i <= n; i++)
p = max(b[1], b[i]);
for(i = 1; i <= n; i++)
if (b[i] == p)
{
cout << i <<" строка имеет максимальную сумму";
break;
}
cout << endl;
}
int main()
{
int n, m;
cin >> n >> m;
sum(n,m);
return 0;
}

вроде правильно!
0
Kostyanych77
172 / 11 / 2
Регистрация: 21.12.2010
Сообщений: 66
22.12.2010, 21:24 #7
Надеюсь терь норм:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
    float sumM=0,sumS=0;int st;
    for(int i=0;i<=n;++i)
    {
        for(int j=0;j<=m;++j)
            sumS+=a[i][j];
        if(sumM<sumS)
        {
            sumM=sumS;
            st=i;
        }
    }
    cout<<endl<<"ÑòðîêГ* Г± Г¬Г*ГЄГ±ГЁГ¬Г*ëüГ*ûìè ýëåìåГ*ГІГ*ìè: "<<st+1<<endl<<"Г…Вё ñóììГ*: "<<sumM;
}
0
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
22.12.2010, 21:27  [ТС] #8
угу) спасибо
0
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
25.12.2010, 18:12  [ТС] #9
Проблема , с Функцией SumMax. Задание такое , Нада найти номер строки, которая имеет максимальную сумму элементов.
У меня неправильно считает, напишите пожалуста код , и обьясните , где у меня ошибка?
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
#include <iostream.h>
const int n=3,m=4;
void InArray ( float a[n][m]);
void PrintArray ( float a[n][m]);
void SumMax (float a[n][m]);
void main()
{
 float a[n][m];
 InArray (a);
 PrintArray (a);
 SumMax (a);
 }
void InArray (float a[n][m])
 
 {
 
   cout<<"Введите масив "<<n<<"*"<<m<<endl;
   for (int i=0;i<n;i++)
{
  for(int j=0;j<m;j++)
  cin>>a[i][j];
  cout<<endl;
} 
   }
    
    
void PrintArray ( float a[n][m])
 {
     cout<<"Матрица: \n ";
 for(int i=0;i<n;i++)
  {
    cout<<endl;
    for(int j=0;j<m;j++)
    cout<<"  "<<a[i][j];
    }
    }
 
    void SumMax (float a[n][m])
  {
        float sumM=0,sumS=0;int st;
        for(int i=0;i<=n;++i)
        {
                for(int j=0;j<=m;++j)
                        sumS+=a[i][j];
                if(sumM<sumS)
                {
                        sumM=sumS;
            st=i;
                }
        }
        cout<<endl<<"Строка с максимальными элементами: "<<st+1<<endl<<"Её сумма: "<<sumM;
}
0
Mиxaил
533 / 438 / 37
Регистрация: 10.12.2009
Сообщений: 1,857
25.12.2010, 18:18 #10
C++
1
for(int j=0;j<=m;++j)
у вас получается (n+1) столбцов

попробуйте везде заменить на строгое ("<") в параметрах цикла
0
asics
Freelance
Эксперт С++
2850 / 1785 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
25.12.2010, 18:18 #11
strag 93, Ану так попробуй
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void SumMax (float a[n][m])
  {
        float sumM=0,sumS;int st;
        for(int i=0;i<n;++i)
        {
               sumS = 0;
               for(int j=0;j<m;++j)
                        sumS+=a[i][j];
                if(sumM<sumS)
                {
                        sumM=sumS;
                        st=i;
                }
        }
1
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
25.12.2010, 18:27  [ТС] #12
Спасибо помогло
0
25.12.2010, 18:27
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.12.2010, 18:27
Привет! Вот еще темы с ответами:

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

Найти сумму элементов массива до первого элемента равного 0, и сумму оставшихся элементов (функции) - C++
Дан массив а1, а2, …, а12. Вычислить сумму элементов этого массива до первого элемента, равного 0, и сумму оставшихся элементов.

Найти сумму тех из элементов a2j(j=1,...,m), для которых a1j имеет значение наибольшего среди значений - C++
Даны натуральное число n, целочисленная матрица i=1,2; j=1,...,m. Найти сумму тех из элементов a2j(j=1,...,m), для которых a1j имеет...

Найти сумму тех из элементов a2j(j=1,...,m), для которых a1j имеет значение наибольшего среди значений a11, a12,...,a1m - C++
нужно решение на с++ Даны натуральное число n, целочисленная матрица i=1,2; j=1,...,m. Найти сумму тех из элементов...


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

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

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