Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Mark33
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 13
1

Не разберусь с матрицами никак!

08.11.2012, 23:38. Просмотров 346. Ответов 4
Метки нет (Все метки)

Даны натуральное число n>=2, действительная квадратная матрица порядка n. Построить последовательность b1,..,bn из нулей и единиц, в которой bi=1 тогда и только тогда, когда элементы i-й строки матрицы образуют возрастающую последовательность.

Если честно, то само задание не вполне понял.

В общем, как говорится, кто чем сможет.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.11.2012, 23:38
Ответы с готовыми решениями:

Никак не разберусь с практической в С++.
НАрод помогите пожалуста с практической. НЕ могу решить, а очень нада срочно. ...

Не разберусь с наследованием класса
Помогите разобраться с классами. Есть класс - шаблон и 2 класса наследуемые от...

Не разберусь в плохом скане кода
У Дейтлов есть код http://xmages.net/upload/f5785fa6.jpg Не разберусь, что...

Ни как не разберусь в чем дело...
Подскажите что не так ругается на функцию в строке 23 говорит что "результатом...

Наследование. я чего-то не разберусь с доступом.объясните пожалуйста
Суть в том, что есть 2 класса.(предок потомок) У каждого класса есть friends...

4
miriganua
132 / 103 / 61
Регистрация: 05.02.2012
Сообщений: 241
09.11.2012, 00:01 2
Надеюсь, что задание понял правильно.

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
53
54
55
56
57
58
59
60
#include <iostream>
 
using std::cout;
using std::cin;
 
bool isItIncreasingSequence(double* sequence, int countOfElements)
{
    double previosElement = sequence[0];
    for (int i = 1; i < countOfElements; i++) 
    {
        if (previosElement >= sequence[i])
        {
            return false;
        }
        previosElement = sequence[i];
    }
    return true;
}
 
int main(int argc, char* argv) 
{
    int n;
    cout << "Enter n:";
    cin >> n;
 
    double** a = new double*[n];
    for (int i = 0; i < n; i++)
    {
        a[i] = new double[n];
    }
    for (int i = 0; i < n; i++) 
    {
        for (int j = 0; j < n; j++)
        {
            cin >> a[i][j];
        }
    }
 
    double* b = new double[n];
    for (int i = 0; i < n; i++)
    {
        if (isItIncreasingSequence(a[i], n))
        {
            b[i] = 1; 
        }
        else
        {
            b[i] = 0;
        }
    }
 
    cout << "Sequence:" << '\n';
    for (int i = 0; i < n; i++)
    {
        cout << b[i] << "  ";
    }
    cout << '\n';
    
    return 0;
}
1
Mark33
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 13
22.11.2012, 22:31  [ТС] 3
Цитата Сообщение от Игорь Миронюк Посмотреть сообщение
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
53
#include <iostream>
using std::cout;
using std::cin;
bool isItIncreasingSequence(double* sequence, int countOfElements)
{
* * double previosElement = sequence[0];
* * for (int i = 1; i < countOfElements; i++) 
* * {
* * * * if (previosElement >= sequence[i])
* * * * {
* * * * * * return false;
* * * * }
* * * * previosElement = sequence[i];
* * }
* * return true;
}
int main(int argc, char* argv) 
{
* * int n;
* * cout << "Enter n:";
* * cin >> n;
double** a = new double*[n];
* * for (int i = 0; i < n; i++)
* * {
* * * * a[i] = new double[n];
* * }
* * for (int i = 0; i < n; i++) 
* * {
* * * * for (int j = 0; j < n; j++)
* * * * {
* * * * * * cin >> a[i][j];
* * * * }
* * }
double* b = new double[n];
* * for (int i = 0; i < n; i++)
* * {
* * * * if (isItIncreasingSequence(a[i], n))
* * * * {
* * * * * * b[i] = 1; 
* * * * }
* * * * else
* * * * {
* * * * * * b[i] = 0;
* * * * }
* * }
cout << "Sequence:" << '\n';
* * for (int i = 0; i < n; i++)
* * {
* * * * cout << b[i] << " *";
* * }
* * cout << '\n';
return 0;
}
Прости, не мог бы ты написать это попроще? просто я не ахти пока в C
0
miriganua
132 / 103 / 61
Регистрация: 05.02.2012
Сообщений: 241
22.11.2012, 22:48 4
Вот чуть упростил:
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
#include <iostream>
 
using std::cout;
using std::cin;
 
bool isItIncreasingSequence(double* sequence, int countOfElements)
{
    for (int i = 1; i < countOfElements; i++) 
    {
        if (sequence[i - 1] > sequence[i])
        {
            return false;
        }
    }
    return true;
}
 
int main(int argc, char* argv) 
{
    int n;
    cout << "Enter n:";
    cin >> n;
 
    double** a = new double*[n];
    for (int i = 0; i < n; i++)
    {
        a[i] = new double[n];
    }
    for (int i = 0; i < n; i++) 
    {
        for (int j = 0; j < n; j++)
        {
            cin >> a[i][j];
        }
    }
 
    double* b = new double[n];
    for (int i = 0; i < n; i++)
    {
        isItIncreasingSequence(a[i], n) ? b[i] = 1 : b[i] = 0;
    }
 
    cout << "Sequence:" << '\n';
    for (int i = 0; i < n; i++)
    {
        cout << b[i] << "  ";
    }
    cout << '\n';
    
    return 0;
}
И я написал на С++, но это легко исправить.
0
TrueBit
96 / 96 / 47
Регистрация: 19.11.2012
Сообщений: 195
22.11.2012, 22:52 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
34
35
36
37
//http://www.cyberforum.ru/cpp-beginners/thread692654.html
#include <iostream>
#include <math.h>
using namespace std;
#define n 4                //размер матрици
void main ()
{
    int matrix[n][n] = { //создаем матрицу порядка n
        {11,12,13,13},
        {21,20,22,23},
        {31,32,33,34},
        {41,42,43,44},
    };
    int b[n]; bool no_b;
    setlocale(LC_ALL,"rus");
    for(int i=0;i<n;i++) b[i]=1; //вначале считаем, что во всех строках возрастающ. посл-сть
    
    for(int i=0; i<n; i++) { //для каждой строки
        no_b=true;
        for(int j=1; (j<n) && no_b; j++) //просматриваем элементы в столбцах
            if(matrix[i][j]<matrix[i][j-1]) { //если очередной элемент оказался меньше предыдущего
                b[i]=0; //то записываем в b с индексом текущей строки что не возрастающая(0)
                no_b=false; //и выходим из цикла по этой строке
            }
    }
    //печать матрици
    cout << "Matrix: \n";
    for(int i=0;i<n;i++) {
        for(int j=0;j<n;j++)
            cout << matrix[i][j] << " ";
        cout << endl;
    }
    cout << "b_i: \n";
    //печать последовательности b
    for(int i=0;i<n;i++) cout << b[i] << " ";
    getchar();
}
1
22.11.2012, 22:52
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.11.2012, 22:52

не разберусь как переработать программу с учетом использования заголовочных файлов, модулей и пользовательских функций
#include &lt;iostream.h&gt; #include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include...

Ну никак не компилится.
Начинаю изучать С++, никак не компилится:...

Никак не разберусь. 3 функции.
Подскажите, пожалуйста, названия функций для счета среднего значения,...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

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