Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
1 / 1 / 1
Регистрация: 04.04.2010
Сообщений: 57

Определить номер строки с наибольшей характеристикой

04.04.2010, 19:02. Показов 2229. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток !
Помогите пожалуйста с программкой, вот задание:

Характеристикой строки целочисленной матрицы назовем сумму её положительных четных элементов. Определить номер строки с наибольшей характеристикой.


Вот я тут написал кое что, пробовал проверять на вывод массива, так он у меня в одномерный строится, что делать?

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
#include <iostream.h>
#include <conio.h>
int main()
{
int i,j,n,m,a[20][20],S,max,imax;
cout<<"N= "; cin>>n;
cout<<"M= "; cin>>m;
cout<<"Vvod matrix: ";
for (i=0;i<n;i++)
  for (j=0;j<m;j++)
   cin>>a[i][j];
   cout<<"Matrix: \n";
for (i=0;i<n;i++)
 for (j=0;j<m;j++)
  cout<<a[i][j]<<"\t";
max=0; imax=1;
for (i=0;i<n;i++)
  for (j=0;j<m;j++)
  {S=0;
  if (a[i][j]%2 & !a[i][j]) S=S+a[i][j];
  if (S>max)
  {
   max=S; imax=i;
  }
  }
cout<<"S= "<<S<<"\n";
cout<<"Nomer= "<<imax;
getch();
return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2010, 19:02
Ответы с готовыми решениями:

Определить номер столбца с наибольшей характеристикой
набросал код, о н выдаёт неверный результат. помогите найти в чём ошибка. Характеристикой столбца матрицы назовем произведение...

Определить номер строки матрицы с наименьшей характеристикой
{ int n, m; cout&lt;&lt;&quot;n = &quot;; cin&gt;&gt;n; cout&lt;&lt;&quot;m = &quot;; cin&gt;&gt;m; int** matr = new int*; time_t t; srand((unsigned) time(&amp;t)); for...

В матрице размерностью MxN найти номер строки с наибольшей суммой элементов и вывести данный номер, а также значение наибольшей суммы
Данная матрица размерности M x N. Найти номер ее строки с наибольшей суммой элементов и вывести данный номер, а также значение наибольшей...

5
 Аватар для Fujiwara no Sai
9 / 9 / 1
Регистрация: 03.04.2010
Сообщений: 22
04.04.2010, 20:21
Я так понял что проблема просто с выводом массива на экран как двумерного?
Если так, то немного подправь цикл вывода вот так:
C++
1
2
3
4
5
6
7
8
for (i=0;i<n;i++)
{
   for (j=0;j<m;j++)
   {
      cout<<a[i][j]<<"\t";
   }
   cout<<endl; //просто переход на новую строку
}
Принцип такой - тут циклы выполняются изнутри как бы. Вот этим мы нагло и воспользуемся - вставим перевод строки после того(можно, конечно, и перед), как внутренний цикл переберет все значений j (при каком-то фиксированном значении i). Т.е., получим, что вот наружный цикл присвоил i значение 0, потом проверил истинность выражений, потом увеличил i на единицу и начался выполнятся внутренний цикл. Внутренний перебрал все значения j, потом выполнился переход на новую строку, и опять начался выполнятся наружный цикл(но уже при значении i==1). Вот так сумбурно описал, но это очень просто, на самом деле. Попробуй поменять значения I, J местами в циклах - будет легче понять как оно выводит на экран.

Тут кстати небольшая непонятка в коде у тебя:
C++
1
2
3
4
5
6
7
8
9
10
max=0; imax=1;
for (i=0;i<n;i++)
  for (j=0;j<m;j++)
  {S=0;
  if (a[i][j]%2 & !a[i][j]) S=S+a[i][j]; //зачем?
  if (S>max)
  {
   max=S; imax=i;
  }
  }
Не совсем понятно что ты тут делаешь
В строке 4 ты выполнил присвоение значения S=0; потом в строке 5 ты S=0+a[i][j]( в случае истины), потом в строке 6 проверил макс.значение, потом цикл for начинает выполнятся опять, и ты опять присваиваешь S=0 (в строке 4), потом опять присваиваешь переменной S сумму нуля и a[i][j] . У тебя тут точно нет ошибки?
1
1 / 1 / 1
Регистрация: 04.04.2010
Сообщений: 57
04.04.2010, 20:59  [ТС]
Там действительно что-то не сходится(((
0
 Аватар для Fujiwara no Sai
9 / 9 / 1
Регистрация: 03.04.2010
Сообщений: 22
04.04.2010, 22:42
Цитата Сообщение от JM007 Посмотреть сообщение
Там действительно что-то не сходится(((
А, ясно - вы тут ошиблись со скобками. Я не сразу заметил, а вот сейчас сел разбираться, и понял:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
max=0;
imax=0;//тут тоже 0, т.к. при первом запуске в строке 16 переменная i будет уже равна 1
for(i=0;i<n;i++)
{
   S=0;//вот  тут нужно было выполнить присвоение
 
   for(j=0;j<m;j++)
      {
         if (a[i][j]%2 & !a[i][j]) 
            S=S+a[i][j];
      }
 
   if (S>max)
      {
         max=S;     
         imax=i;
      }
}
Вот где-то так будет выглядеть. По идее должна работать(под рукой нет компилятора - сам проверить не могу). Если будет не совпадать с ответом, тогда в строке 2 замените imax=1, хотя вроде все правильно

Да, я бы еще добавил вот такой фрагмент в программу(сразу после того, что выше):
C++
1
2
if(imax==0)
   cout<<"У данной матрицы нет строки с наибольшей характеристикой...";
Объясню почему. Первоначально значение imax равно нулю. Потом в строке 16 мы этой переменной присваиваем номер строки с наибольшей характеристикой. Но, строка 16 не выполнится, если мы не нашли вообще строк в матрице, которые имели бы характеристику(, например, единичная матрица, или любая другая, элементами которой есть отрицательные числа или т.п., т.е. матрица не удовлетворяющая условию задачи). Вот мы и сделали проверку - если за всю программу переменная imax не изменилась, значит матрица не подходит по условию
1
1 / 1 / 1
Регистрация: 04.04.2010
Сообщений: 57
05.04.2010, 16:01  [ТС]
Спасибо конечно , но программа все равно не работает ...
Там как я понял сначало надо найти в строках положительные и четные элементы, ну типа так, но она тоже не работает:
C++
1
2
for (S=i=0;i<n;i++)
 {if (a[i][j]%2 && a[i][j]>0) S=S+a[i][j];}
А потом в столбце найти наибольшую сумму:
C++
1
2
3
4
5
6
for (j=0;j<m;j++)
  { 
  if (S>max)
  {
   max=S; imax=i;
  }
незнаю че делать

У меня результат такой выходит:
S=0
Nomer=0 //Это при твоем случае, а при прошлом:
S=0;
Nomer=1;

Добавлено через 37 минут
Спасибо, я разобрался, прога работает
Вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
max=a[1][1]; imax=1;
for (i=0;i<n;i++)
 {S=0;
  for (j=0;j<m;j++)
  { if ((a[i][j]%2==0) && (a[i][j]>0)) S=S+a[i][j];}
  if (S>max)
  {
   max=S; imax=i+1;// вот здесь все время 0 выходил, это из-за матрицы, она же от 0 до определенного числа :)
  }
 
}
if(imax==0)
   cout<<"У данной матрицы нет строки с наибольшей характеристикой...";
cout<<"Max= "<<max<<"\n";
cout<<"Nomer= "<<imax;
0
0 / 0 / 0
Регистрация: 25.04.2010
Сообщений: 7
23.05.2010, 13:36
а не могли бы помочь написать эту же программу на паскале пожалуйста ?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.05.2010, 13:36
Помогаю со студенческими работами здесь

Матрица. Найти номер ее ряда с наибольшей суммой элементов и вывести данный ее номер, а также значение наибольшей суммы
Дана матрица размерности M x N. Найти номер ее ряда з найбольшою суммой элементов и вивести даный ее номер а также значение ...

Дана матрица размера MxN. Найти номер ее строки с наибольшей суммой элементов и вывести данный номер, а также
Дана матрица размера MxN. Найти номер ее строки с наибольшей суммой элементов и вывести данный номер, а также значение наибольшей суммы.

Определить номер строки с наименьшей характеристикой.
Характеристикой строки целочисленной матрицы назовем сумму ее элементов c четными номерами столбцов. Определить номер строки с наименьшей...

Дана матрица размера M × N. Найти номер ее строки с наибольшей суммой элементов и вывести данный номер, а также значение наибольшей суммы.
Дана матрица размера M × N. Найти номер ее строки с наибольшей суммой элементов и вывести данный номер, а также значение наибольшей суммы.

Определить номер строки с наибольшей суммой элементов
Составить программу обработки матрицы размерности NxN. В программе предусмотреть ввод, вывод матрицы и результата . Ввод, вывод матрицы и...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru