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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [С++] Матрица 8x8 
:(
    Опции темы
devil1204
Дата 5.6.2007, 19:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Для заданной матрицы размером 8 на 8 найти такие k, что k-я строка матрицы совпадает с k-м столбцом (оформить в виде процедуры).
Найти сумму эл-тов в тех строках, которые содержат хотя бы один отрицательный эл-т
PM MAIL   Вверх
Dov
Дата 8.6.2007, 09:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



Цитата(devil1204 @  5.6.2007,  19:40 Найти цитируемый пост)
Для заданной матрицы размером 8 на 8 найти такие k, что k-я строка матрицы совпадает с k-м столбцом (оформить в виде процедуры).

Кто-нибудь может объяснить, что здесь нужно сделать? Я ничего не понял.  smile 


--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
zkv
Дата 8.6.2007, 10:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



****


Профиль
Группа: Участник Клуба
Сообщений: 2133
Регистрация: 23.7.2006
Где: Санкт-Петербург

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



Цитата(Dov @  8.6.2007,  09:47 Найти цитируемый пост)
Кто-нибудь может объяснить, что здесь нужно сделать?

попробую  smile 
1. перебираем числа от к=1 до к=8, смотрим, если к-я  строка поэлементно равна транспонированному к-му столбцу, то выводим к. Оформить в виде функции. 

2. тут без перевода понятно вроде:
Цитата(devil1204 @  5.6.2007,  19:40 Найти цитируемый пост)
Найти сумму эл-тов в тех строках, которые содержат хотя бы один отрицательный эл-т 


Перевод производил я  smile  За достоверность не ручаюсь, поскольку плохо владею родным языком автора  smile 
PM MAIL   Вверх
Dov
Дата 8.6.2007, 10:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



zkv, спасибо за перевод. smile

Цитата(zkv @  8.6.2007,  10:04 Найти цитируемый пост)
За достоверность не ручаюсь, поскольку плохо владею родным языком автора 

Гы-гы... Стало быть, я им совсем не владею.  smile 




--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
apook
Дата 8.6.2007, 13:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата

#include <iostream.h>
#include <conio.h>


void procedurovajaPROCEDURA( int omega[][ 8 ] )
{
int i, j, q, c, gravel=0,
pegas[ 8 ][ 2 ]={ {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1},
                  {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1} };

for( i=0, c=0; i<8; i++ )               //столбцевой
{
    for( q=0; q<8; q++ )                //строковой
    {
        for( j=0, gravel=0; j<8; j++ )  //элементовый 
        {
            if( omega[ q ][ j ]!=omega[ j ][ i ] )
            {
                gravel=1;
                break;
                }
            }

           //ююю
            if( gravel==0 )
            {
             //если прошелся без ошибок     
                pegas[ c ][ 0 ]=i; //запомн столбец
                pegas[ c ][ 1 ]=q; //запомн строку
                ++c; 
                } 
          //яяя
        }
    }

for( i=0; i<8; i++ )
{
    if( pegas[ i ][ 0 ]>-1 && pegas[ i ][ 1 ]>-1 )
        cout << "Column " << pegas[ i ][ 0 ] << " Row " << pegas[ i ][ 1 ] << endl;
    }

return;
}


void SummaElementovTehStrok( int omega[][ 8 ] )
{
int i, j, c, X=0;

for( i=0; i<8; i++ )
{
    for( j=0; j<8; j++ )
    {
        if( omega[ i ][ j ]<0 )
        {
            for( c=0; c<8; c++ )
                X+=omega[ i ][ c ];
            cout << "Row " << i << " Summa Elementov =" << X << endl;
            break;
            }  
        }
    }

return;
}

void main()
{
int matrixovajaMATRIXA[][ 8 ]=
{
            {1,  2,  3,  4,  5,  1,  0,  0}, //+--
            {2,  5,  1,  7,  0,  2,  4,  3},
            {3,  3,  0,  3,  5,  3,  1,  8},
            {4,  9,  2,  9,  9,  4,  4,  4},
            {5,  0,  5,  9,  1,  5,  7,  7}, //+--
            {1,  5,  5,  0,  5,  1,  4,  9},
            {0,  3,  8,  4,  7,  9,  0,  0}, //+--
            {0,  1, -1,  7,  7,  1, -1,  0}
//           +               +           +
//           |               |           |          
    };

procedurovajaPROCEDURA( matrixovajaMATRIXA );
cout << "<--------------------------------->" << endl;
SummaElementovTehStrok( matrixovajaMATRIXA );

return;
}


Это сообщение отредактировал(а) apook - 9.6.2007, 15:01


--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Dov
Дата 8.6.2007, 13:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



Если что не так, то все претензии предъявлять zkv, это он во всём виноват...   smile   smile 

Код
#include <iostream.h>
#include <iomanip.h>

#define SZ 8 

bool Check(int matr[][SZ], int i)
{
    for(int j = 0; j < SZ; j++)
        if(matr[i][j] != matr[j][i])
            return false;

    return true;
}

bool isNegative(int* ar)
{
    for(int i = 0; i < SZ; i++)
        if(ar[i] < 0)
            return true;

    return false;
}

int main()            
{
    int matr[][SZ] = {
        1, 8, -1, 1, 6, 5, 4, -1,
        8, 1,  3, 0, 2, 1, 9,  0,
       -2, 3,  4, 7, 3, 2, 1,  4,
        1, 0,  7, 9, 6, 7, 4,  1,
        1, 2, -5, 1, 6, 5, 4,  1,
        5, 1,  2, 7, 5, 3, 2,  5,
        3, 9,  4, 7, 3, 2, 1,  4,
       -1, 0,  4, 1, 1, 5, 4,  3,
    };
    bool check = false;
    int  sum   = 0;
    int  i, j;

    cout << "Matrix: \n";
    for(i = 0; i < SZ; i++)
    {
        for(j = 0; j < SZ; j++)
            cout << setw(3) << matr[i][j];
        cout << endl;
    }

    for(i = 0; i < SZ; i++)
    {
        if(Check(matr, i))
        {
            cout << "\nk = " << i + 1;
            check = true;
        }
    }

    if(!check)
        cout <<    "\nnot found...";
    else 
        check = false;

    cout << "\n";
    for(i = 0; i < SZ; i++)
    {
        sum = 0;
        if(isNegative(matr[i]))
        {
            for(j = 0; j < SZ; j++)
                sum += matr[i][j];

            cout << "\nsum #" << i + 1 << ": " << sum;
            check = true;
        }
    }

    if(!check)
        cout <<    "\nnot found...";

    cout << "\n\n";

    return 0;
}




--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Dov
Дата 8.6.2007, 14:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



apook, вот вывод твоей программы.   smile 
Интуиция мне говорит, что здесь что-то не так.  smile 
Код

    int matrixovajaMATRIXA[][ 8 ]=
    {
        {1,  2,  3,  4,  5,  1,  0,  0}, //+--
        {2,  5,  -1,  7,  0,  2,  -4,  3},
        {3,  3,  0,  3,  5,  3,  1,  8},
        {4,  9,  2,  9,  9,  4,  4,  4},
        {-5,  0,  5,  9,  -1,  5,  7,  7}, //+--
        {1,  5,  5,  0,  5,  1,  4,  9},
        {0,  3,  8,  4,  7,  9,  0,  0}, //+--
        {0,  1, -1,  7,  7,  1,  -1,  0}
        //           +               +           +
        //           |               |           |          
    };


Код

Column 7 Row 6
<-----------------------------
Row 1 Summa Elementov =14
Row 1 Summa Elementov =28
Row 4 Summa Elementov =55
Row 4 Summa Elementov =82
Row 7 Summa Elementov =96
Row 7 Summa Elementov =110
Press any key to continue




--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
zkv
Дата 8.6.2007, 16:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



****


Профиль
Группа: Участник Клуба
Сообщений: 2133
Регистрация: 23.7.2006
Где: Санкт-Петербург

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



Цитата(Dov @  8.6.2007,  13:45 Найти цитируемый пост)
Если что не так, то все претензии предъявлять zkv, это он во всём виноват...

я тоже, кстати, жду ответа автора, хочу узнать, правильно я перевел или нет  smile 
PM MAIL   Вверх
devil1204
Дата 8.6.2007, 23:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Хех...спасибо всем огромное, даже огромнейшее...но я и сам-то не совсем понимаю, что от меня хотят...но думаю, что догадки правильные =)) На зачете узнаю. 
PM MAIL   Вверх
apook
Дата 9.6.2007, 05:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата

apook, вот вывод твоей программы.    
Интуиция мне говорит, что здесь что-то не так.   

Научись сначала копмелировать ...
на Борлэнде и на Вижуале выдает верный резалтут
Цитата

Column 0 Row 0
Column 4 Row 4
Column 7 Row 6
<--------------------------------->
Row 7 Summa Elementov =16

По поводу твоего кода то строка может совпасть и с несовпадающим по номеру
столбцем 


--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Dov
Дата 9.6.2007, 08:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



Цитата(apook @  9.6.2007,  05:17 Найти цитируемый пост)
Научись сначала копмелировать ...
на Борлэнде и на Вижуале выдает верный резалтут

Хамишь, сынок?  smile 
Я же тебе матрицу показал, которая выдаёт такой результат. Или ты её не заметил?  smile 

Цитата(apook @  9.6.2007,  05:17 Найти цитируемый пост)
По поводу твоего кода то строка может совпасть и с несовпадающим по номеру столбцем 

Читаем внимательно. 
Цитата(devil1204 @  5.6.2007,  19:40 Найти цитируемый пост)
такие k, что k-я строка матрицы совпадает с k-м столбцом





--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
apook
Дата 9.6.2007, 09:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата

Я же тебе матрицу показал, которая выдаёт такой результат. Или ты её не заметил?

когда ты мне ее показал, и зачем мне ее показывать, я по поводу своего кода
то что он у тебя выводит не есть правда, я пробовал компилировать на Борпанде
на VS2003 результат одинаков и вовсе не то что ты там изобразил типа глюки
Цитата

Column 7 Row 6
<-----------------------------
Row 1 Summa Elementov =14
Row 1 Summa Elementov =28
Row 4 Summa Elementov =55
Row 4 Summa Elementov =82
Row 7 Summa Elementov =96
Row 7 Summa Elementov =110
Press any key to continue
 
че-то лжешь папаша



--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Dov
Дата 9.6.2007, 10:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



Цитата(apook @  9.6.2007,  09:30 Найти цитируемый пост)
когда ты мне ее показал,

apook, у тебя проблемы со зрением, что-ли?  smile 
Вот же она:
Цитата(Dov @  8.6.2007,  14:07 Найти цитируемый пост)
 
int matrixovajaMATRIXA[][ 8 ]=    { 
      {1,  2,  3,  4,  5,  1,  0,  0}, //+--  
      {2,  5,  -1,  7,  0,  2,  -4,  3},  
      {3,  3,  0,  3,  5,  3,  1,  8},    
      {4,  9,  2,  9,  9,  4,  4,  4},     
      {-5,  0,  5,  9,  -1,  5,  7,  7}, //+--  
      {1,  5,  5,  0,  5,  1,  4,  9},   
      {0,  3,  8,  4,  7,  9,  0,  0}, //+--    
      {0,  1, -1,  7,  7,  1,  -1,  0}  
      //           +               +           +     
      //           |               |           |           
   };


Цитата(apook @  9.6.2007,  09:30 Найти цитируемый пост)
 и зачем мне ее показывать

Что бы ты видел результаты своей работы.  smile 
Цитата(apook @  9.6.2007,  09:30 Найти цитируемый пост)
че-то лжешь папаша

Гы-гы, ты что же думаешь, что я эти результаты вывода на экран сам нарисовал?   smile  
Нет. Это выдала твоя программа, когда обработала данные этой матрицы.  smile  



--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
apook
Дата 9.6.2007, 11:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Посмотри внимательно на мою
Код

int matrixovajaMATRIXA[][ 8 ]=
{
            {1,  2,  3,  4,  5,  1,  0,  0}, //+--
            {2,  5,  1,  7,  0,  2,  4,  3},
            {3,  3,  0,  3,  5,  3,  1,  8},
            {4,  9,  2,  9,  9,  4,  4,  4},
            {5,  0,  5,  9,  1,  5,  7,  7}, //+--
            {1,  5,  5,  0,  5,  1,  4,  9},
            {0,  3,  8,  4,  7,  9,  0,  0}, //+--
            {0,  1, -1,  7,  7,  1,  1,  0}
//           +               +           +
//           |               |           |          
    };

и на то что показал ты
Код

int matrixovajaMATRIXA[][ 8 ]=    { 
      {1,  2,  3,  4,  5,  1,  0,  0}, //+--  
      {2,  5,  -1,  7,  0,  2,  -4,  3},  
      {3,  3,  0,  3,  5,  3,  1,  8},    
      {4,  9,  2,  9,  9,  4,  4,  4},     
      {-5,  0,  5,  9,  -1,  5,  7,  7}, //+--  
      {1,  5,  5,  0,  5,  1,  4,  9},   
      {0,  3,  8,  4,  7,  9,  0,  0}, //+--    
      {0,  1, -1,  7,  7,  1,  -1,  0}  
      //           +               +           +     
      //           |               |           |           
   };

ЗАЧЕМ ПОМЕНЯЛ? во первых, а во вторых тогда тот результат что выдала скомпелированнная
тобой прога тот что и должна была вывести эта программа, а именно глюк да действительно
в ней есть глюк при подсчете элементов строки в которой есть отрицательный эл-т если их несколько происходит несколько раз для одной и той-же строки, я переделывать не буду
все-равно уже есть пример без ошибок (хотя не тэстировал) , хотя и ошибка легкоисправимая

Неахота мне Dov c тобой перепираться


--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Dov
Дата 9.6.2007, 11:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

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



apook, если ты считаешь, что твоя прога работает правильно и выдаёт верные результаты, тогда расслабься и отдыхай.  smile 
Лично мне глубоко пох. Я ей пользоваться не буду.  smile 


--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

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


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

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

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

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


 




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


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

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