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

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

Восстановить пароль Регистрация
 
KONAN-VARVAR
2 / 2 / 0
Регистрация: 09.06.2013
Сообщений: 59
13.06.2013, 11:36     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #1
помогите Пожалуста с задачей я не знаю как правильно прописать, чтоб он выводил число строки((( помогите пожалуста((
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
#include<iostream>
#include <conio.h>
#include <cmath> 
#include <iomanip>
#include <time.h> 
using namespace std;
 
int main() {
long s;
int n,m;
cin>>n;
cin>>m;
int arr[n][m];
{srand(time(NULL));
    for (int i=0;i<n;i++)
    
     {
         for(int j=0;j<m;j++)
         arr[i][j]=rand ()%20-10;
     }
     }
 
    for (int i=0; i<n; i++)
{
for (int j=0; j<m; j++)
cout<<setw(2)<<arr[i][j]; 
cout<<endl;
}   float max = 3200000;
    for (int i = 0; i < n; i++)
    {
        float sum = 0;
        for (int j = 0; j < m; j++)
        {
            if(arr[i][j]%2!=0&&arr[i][j]<0)
            {
            sum += arr[i][j]; 
            }
        }
        if (max<sum) 
        {
            max=sum;
            s+=i;
        }
    
    }
    cout << "stroka :" << s << endl;
   ///   cout << proiz <<" ";
 
return 0;}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.06.2013, 11:36     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая
Посмотрите здесь:

C++ Дана последовательность целых чисел, за которой следует 0.Найти количество нечетных элементов этой последовательности.
C++ С++ Дан двумерный массив целых чисел. В каждом столбце найти сумму и количество нечетных чисел.
C++ Дано двумерный массив целых чисел. В каждом столбце найти сумму и количество чисел.(исправить)
C++ дано двумерный массив целых чисел найти столбик с минимальной суммой элементов
C++ Двумерный массив: найти номер строки, в которой находится самое минимальное количество одинаковых элементов
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Пaтрик
 Аватар для Пaтрик
394 / 387 / 38
Регистрация: 21.01.2012
Сообщений: 972
Завершенные тесты: 1
13.06.2013, 11:48     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #2
C++
1
2
#include <numeric_limits>
float max = std::numeric_limit<float>::min();
Вместо
C++
1
s+=i;
это
C++
1
s = i;
KONAN-VARVAR
2 / 2 / 0
Регистрация: 09.06.2013
Сообщений: 59
13.06.2013, 11:56  [ТС]     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #3
Пaтрик, говорит ошибка numeric_limits: No such file or directory
Пaтрик
 Аватар для Пaтрик
394 / 387 / 38
Регистрация: 21.01.2012
Сообщений: 972
Завершенные тесты: 1
13.06.2013, 11:59     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #4
C++
1
2
3
#include <cfloat>
 
float max = FLT_MIN;
KONAN-VARVAR
2 / 2 / 0
Регистрация: 09.06.2013
Сообщений: 59
13.06.2013, 12:07  [ТС]     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #5
Пaтрик, он всеровно не правильно считает и выводит выводит3676400(((
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 <cfloat>
#include<iostream>
#include <conio.h>
#include <cmath> 
#include <iomanip>
#include <time.h> 
using namespace std;
 
int main() {
int s;
int n,m;
cin>>n;
cin>>m;
int arr[n][m];
{srand(time(NULL));
    for (int i=0;i<n;i++)
    
     {
         for(int j=0;j<m;j++)
         arr[i][j]=rand ()%20-10;
     }
     }
 
    for (int i=0; i<n; i++)
{
for (int j=0; j<m; j++)
cout<<setw(2)<<arr[i][j]; 
cout<<endl;
}float max = FLT_MIN;
    
//float max = 3200000;
    for (int i = 0; i < n; i++)
    {
        float sum = 0;
        for (int j = 0; j < m; j++)
        {
            if(arr[i][j]%2!=0&&arr[i][j]<0)
            {
            sum += arr[i][j]; 
            }
        }
        if (max<sum) 
        {
            max=sum;
            s=i;
        }
    
    }
    cout << "stroka :" << s << endl;
   
 
return 0;}
Пaтрик
 Аватар для Пaтрик
394 / 387 / 38
Регистрация: 21.01.2012
Сообщений: 972
Завершенные тесты: 1
13.06.2013, 12:31     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #6
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
#include <cstdlib>
#include <iostream>
#include <cmath> 
#include <iomanip>
#include <time.h> 
 
using namespace std;
 
int main() {
    int s = -1;
    int n, m;
    cin>>n;
    cin>>m;
    int arr[n][m];    
    srand(time(NULL));
    for (int i=0;i<n;i++)
    {
        for(int j = 0; j < m; j++)
            arr[i][j] = rand () % 20 - 10;
    }
    
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
            cout << setw(2) << arr[i][j]; 
        cout << endl;
    }
    int max = INT_MIN;
    
    for (int i = 0; i < n; i++)
    {
        int sum = 0;
        bool found = false;
        for (int j = 0; j < m; j++)
        {
            if(arr[i][j] % 2 != 0 && arr[i][j] < 0)
            {
                sum += arr[i][j]; 
                found = true;
            }
        }
        if (max < sum && found) 
        {
            max = sum;
            s = i;
        }
    }
    cout << "stroka :" << s << endl;
    return 0;
}
Все из-за того, что числа с плавающей точкой нормально не сравниваются. У вас же массив целых чисел, зачем вы переменные max и sum сделали float? С int нормально работает.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.06.2013, 12:34     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая
Еще ссылки по теме:

C++ ДИНАМИЧЕСКИЕ МАССИВЫ.Найти номер строки, в которой сумма отрицательных нечетных элементов самая большая
Определить номер строки матрицы С (N, N), сумма элементов которого наибольшая C++
Определить номер строки массива натуральных чисел, сумма чисел которой наибольшая C++

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

Или воспользуйтесь поиском по форуму:
KONAN-VARVAR
2 / 2 / 0
Регистрация: 09.06.2013
Сообщений: 59
13.06.2013, 12:34  [ТС]     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая #7
Пaтрик, все понял я просто не внимательный. Спасиба большое вам )))))
Yandex
Объявления
13.06.2013, 12:34     Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая
Ответ Создать тему
Опции темы

Текущее время: 05:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru