Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C++] Определить минимум среди сумм элементов, матрицы 
:(
    Опции темы
Fish24
Дата 23.12.2013, 18:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 19.12.2013

Репутация: нет
Всего: нет



Никак не получается сделать эту лабу (((( Помогите пожалуйстааааааа smile  smile  smile 
 
В visual studio, C++


Дана целочисленная квадратная матрица. 
Определить: минимум среди сумм модулей элементов диагоналей, параллельных побочной диагонали матрицы.
PM MAIL   Вверх
interv
Дата 25.12.2013, 12:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 93
Регистрация: 24.1.2012

Репутация: 4
Всего: 4



Задача в том, чтобы понять условие задачи? Я сломал мозг  smile  smile 

UPD: Сделал http://ideone.com/c5FrsU

Код

#include <iostream>
#include <math.h>
const int m_Size = 5;

int GetIndex(int row, int col, int rows = m_Size)
{
  return col*rows + row;
}

int abs(int x)
{
  return x<0?-x:x;
}

int main()
{
  int matrix[m_Size*m_Size];
  for (int index=0; index<m_Size*m_Size; ++index)
    matrix[index] = abs(round(sin(index+1)*90000)) + 10000;
  std::cout << "Matrix:\n";
  for (int row=0; row<m_Size; ++row)
  {
    for (int col=0; col<m_Size; ++col)
      std::cout << matrix[GetIndex(row, col)] << " ";
    std::cout << "\n";
  }
  int min = matrix[GetIndex(1, 1)]; // Берем первый элемент - предположим это минимум
  int xF = 0;
  int yF = 0;
  while (xF<m_Size && yF<m_Size)
  {
    int x = xF;
    int y = yF;
    int summ = 0;
    std::cout << "\nsumm: ";
    while (x<m_Size && y>=0)
    {
      int modul = abs(matrix[GetIndex(x, y)]);
      summ += modul;
      ++x;
      --y;
      std::cout << modul << ((x<m_Size && y>=0) ? " + " : " = ");
    }
    std::cout << summ;
    if (min>summ)
      min = summ;
    if (yF<m_Size-1)
      ++yF;
    else
      ++xF;
  }
  std::cout << "\n\nmin: " << min;
}


Это сообщение отредактировал(а) interv - 25.12.2013, 13:05
PM MAIL   Вверх
Fish24
Дата 26.12.2013, 20:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 19.12.2013

Репутация: нет
Всего: нет



Цитата(interv @ 25.12.2013,  12:19)
Задача в том, чтобы понять условие задачи? Я сломал мозг  smile  smile 

UPD: Сделал http://ideone.com/c5FrsU

Код

#include <iostream>
#include <math.h>
const int m_Size = 5;

int GetIndex(int row, int col, int rows = m_Size)
{
  return col*rows + row;
}

int abs(int x)
{
  return x<0?-x:x;
}

int main()
{
  int matrix[m_Size*m_Size];
  for (int index=0; index<m_Size*m_Size; ++index)
    matrix[index] = abs(round(sin(index+1)*90000)) + 10000;
  std::cout << "Matrix:\n";
  for (int row=0; row<m_Size; ++row)
  {
    for (int col=0; col<m_Size; ++col)
      std::cout << matrix[GetIndex(row, col)] << " ";
    std::cout << "\n";
  }
  int min = matrix[GetIndex(1, 1)]; // Берем первый элемент - предположим это минимум
  int xF = 0;
  int yF = 0;
  while (xF<m_Size && yF<m_Size)
  {
    int x = xF;
    int y = yF;
    int summ = 0;
    std::cout << "\nsumm: ";
    while (x<m_Size && y>=0)
    {
      int modul = abs(matrix[GetIndex(x, y)]);
      summ += modul;
      ++x;
      --y;
      std::cout << modul << ((x<m_Size && y>=0) ? " + " : " = ");
    }
    std::cout << summ;
    if (min>summ)
      min = summ;
    if (yF<m_Size-1)
      ++yF;
    else
      ++xF;
  }
  std::cout << "\n\nmin: " << min;
}

Спасибо! А как сделать так, чтобы мы сами вводили матрицу?
PM MAIL   Вверх
interv
Дата 31.12.2013, 09:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 93
Регистрация: 24.1.2012

Репутация: 4
Всего: 4



Код

for (int row=0; row<m_Size; ++row)
{
  for (int col=0; col<m_Size; ++col)
  {
     cout << "Введите A[" << row << ' ' << col <<"]: ";
     cin >> matrix[GetIndex(row, col)];
   }
}

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0792 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.