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

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

Войти
Регистрация
Восстановить пароль
 
Lainus
0 / 0 / 0
Регистрация: 19.03.2009
Сообщений: 9
#1

Элемент из программы с массивами - C++

21.07.2009, 19:59. Просмотров 836. Ответов 5
Метки нет (Все метки)

Не могу придумать правильный алгоритм.
Нужно найти произведения отрицательных элементов в строках матрицы.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int k,mas[4],i,j,matr[4][4],c=0;
cout<<"Vvedite matricy 4x4: \n";
for (i=0; i<4; i++)
for (j=0; j<4; j++)
cin>>matr[i][j];
for (i=0; i<4; i++)
{
for (j=0; j<4; j++)
if(matr[i][j]<0)
/* Пробовал так, но неполучается....
k++;
mas[c++]=matr[i][j];
for(int u=0; u<k-1; u++)
mas[u]*=mas[u+1];
*/ 
}
for (i=0; i<4; i++)
cout<<"\n "<<mas[i]<<"  ";
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.07.2009, 19:59     Элемент из программы с массивами
Посмотрите здесь:

Объясните код программы работы с двумерными массивами - C++
#include &lt;time.h&gt; #include &lt;stdlib.h&gt; #include &lt;iostream&gt; #include &lt;cmath&gt; #include &lt;iomanip&gt; using namespace std; const int...

Наибольший элемент матрицы в левом углу - объяснить код программы - C++
Здравствуйте. У меня есть программа, но я не могу понять как она работает. Пожалуйста, объясните ее и, если можете, упростите... ...

Как узнать, сколько памяти занимает тот или иной элемент программы? - C++
Товарищи, подскажите, пожалуйста, ответы на следующие вопросы: 1) Есть какие-либо средства определения, сколько памяти жрёт программа в...

Вывести содержимое списка в следующем порядке: первый элемент, последний элемент, второй элемент, предпоследни - C++
#include &lt;iostream&gt; #include &lt;list&gt; #include &lt;iterator&gt; void output(std::list&lt;int&gt; myList, std::list&lt;int&gt;::iterator iter1,...

Строки. Как найти в слове первый элемент? Второй элемент, последний элемент? - C++
как найти в слове первый элемент?Второй элемент,последний элемент.С помощью каких операторов это делается??

Как спросить у программы: "Если существует соседний элемент массива по вертикали или горизонтали, то ..." - C++
Как спросить у программы: &quot;Если существует соседний элемент массива по вертикали или горизонтали, то ...&quot; Собственно пробывал так: ...

матрица с массивами - C++
Задание: дана челочисленная квадратная матрица. Определить 1)сумму элементов в тех столбцах, которые не содержат отрицательных...

программа с массивами - C++
помогите,пожалуйста, студенту написать прогу на си. Такая вот задача Дан одномерный массив А, состоящий из N элементов. Исключить из...

задача с массивами - C++
3)Задан массив размером 10.Сформировать два массива размером 5,включая в первый элементы исходного массива с четными индексами, а во...

Работа с массивами - C++
Я ввожу переменную, например 456. Программа розбивает её и записьІвает в массив. int Array Array = 4; Array = 5; Array = 6;


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zim22
depict1
276 / 141 / 2
Регистрация: 11.07.2009
Сообщений: 606
21.07.2009, 20:04     Элемент из программы с массивами #2
Цитата Сообщение от Lainus Посмотреть сообщение
/* Пробовал так, но неполучается....
пробовать не нужно. сформулируйте алгоритм "на листике" - пусть он там "заработает". потом перевёдёте на С++
Цитата Сообщение от Lainus Посмотреть сообщение
Не могу придумать правильный алгоритм.
алгоритм:
1) пройтись по строкам матрицы
2) в каждой строке матрицы обнаруживать отрицательные значения
3) умножать эти отрицательные значения одно на другое, пока строка матрицы не подошла к концу
4) перейти к следующей строке матрицы
5) повторить пункт 2
Rififi
2338 / 1053 / 44
Регистрация: 03.05.2009
Сообщений: 2,656
21.07.2009, 20:06     Элемент из программы с массивами #3
этот алгоритм зовётся accumulate_if
C++
1
2
3
4
5
6
7
8
9
10
11
12
template <typename _InIt, typename _Ty, typename _BinaryOp, typename _Pred1>
inline _Ty accumulate_if(_InIt _First, _InIt _Last, _Ty _Val, _BinaryOp _Op, _Pred1 _Pred)
{
    for (; _First != _Last; ++_First)
        if (_Pred(*_First))
            _Val = _Op(_Val, *_First);
    return (_Val);
}
 
int a[2][2];
// произведение для первой строки
int mul = accumulate_if(a[0], a[0]+2, 1, std::multiplies<int>(), std::bind2nd(std::less<int>(), 0));
odip
Эксперт С++
7155 / 3295 / 59
Регистрация: 17.06.2009
Сообщений: 14,164
21.07.2009, 20:42     Элемент из программы с массивами #4
C++
1
2
3
4
5
6
for (i=0; i<4; i++) {
    mas[i]= 1;
    for (j=0; j<4; j++) {
        if ( matr[i][j]<0 ) { mas[i]*= matr[i][j]; }
    }
}
pigah
12 / 12 / 2
Регистрация: 05.07.2009
Сообщений: 147
Записей в блоге: 1
21.07.2009, 21:09     Элемент из программы с массивами #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
31
32
33
#include "stdafx.h"
#include <windows.h>
#include <iostream>
#include <iomanip>
 
 
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{   
    const int N=5,A=-10,B=10;
    int a[N][N],i,j,p;
    srand(GetTickCount());
    for(i=0;i<N;i++){
        for(j=0;j<N;j++){
            a[i][j]=A+rand()%(B-A+1);
            }//for j
        }//for i
    for(i=0;i<N;i++){
        for(j=0;j<N;j++){
            cout<<setw(4)<<a[i][j];
            if(j+1%8==0)                cout<<"\n";
            }//for j
        }//for i
    p=1;
    for(i=0;i<N;i++){
        for(j=0;j<N;j++){
            if(a[i][j]<0)
                p*=a[i][j];
            }//for j
        }//for i
    cout<<"\n\n"<<p<<"\n\n";
    return 0;
}
odip
Эксперт С++
7155 / 3295 / 59
Регистрация: 17.06.2009
Сообщений: 14,164
22.07.2009, 21:41     Элемент из программы с массивами #6
2pigah: Это произведение по всей матрице, а нужно для каждой строки отдельно.
Yandex
Объявления
22.07.2009, 21:41     Элемент из программы с массивами
Ответ Создать тему
Опции темы

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