0 / 0 / 0
Регистрация: 14.12.2009
Сообщений: 11
1

матрица

12.03.2010, 15:44. Показов 862. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
дан двумерный массив чисел (любой)
необходимо распределитьв этой матрице нечётные числа по возрастанию,а чётные по убыванию
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.03.2010, 15:44
Ответы с готовыми решениями:

Дана матрица целых чисел, из n строк и n столбцов (n < = 100).Определить является ли матрица нулевой (состоит из одних нулей)
#include &lt;iostream.h&gt; #include &lt;iomanip.h&gt; #include&lt;conio.h&gt; void main() { int mas; int N;...

Дана матрица целых чисел, из n строк и n столбцов (n < = 100).Определить является ли матрица нулевой (состоит из одних нулей)
#include &lt;iostream.h&gt; #include &lt;iomanip.h&gt; #include &lt;stdlib.h&gt; int main(int argc, char* argv) {...

Нужны преобразования: список смежных вершин -> список инцидентных ребер -> матрица инцидентности -> матрица смежности
Нужны такие преобразования: список смежных вершин -&gt; список инцидентных ребер -&gt; матрица...

Шаблон функции матрица-матрица
не понимаю как сделать шаблон для этого функции. Нужно написать для типа int и float. Операция...

2
3 / 3 / 2
Регистрация: 01.03.2010
Сообщений: 3
12.03.2010, 19:48 2
Лучший ответ Сообщение было отмечено Zeolan как решение

Решение

Если распределить в Вашем понимании это упорядочить, не меняя расположения чётных и нечётных элементов, то вот код:

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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <iostream>
#include <ctime>
#include <stdlib.h>
 
#define M 3
#define N 3
#define MaxValue 255
using namespace std;
 
void PrintArray(int Array[M][N])
{
    for(int i = 0; i < M; i++)
    {
        for(int j = 0; j < N; j++)
            cout << Array[i][j] << "\t";
        cout << endl;
    }
}
 
int main()
{
    int Array[M][N], valPrevOdd, valPrevEven, k = 0, IterIs;
    int indFirstOdd = -1, indFirstEven = -1, indPrevOdd = -1, indPrevEven = -1;
    //Заполнение массива случайными числами
    srand( (unsigned)time( NULL ) );
    for(int i = 0; i < M; i++)
        for(int j = 0; j < N; j++)
            Array[i][j] = rand() % MaxValue;
    PrintArray(Array);
    k = 0;
    //Находим первое нечётное число и принимаем его за минимум.
    do
    {
        if((Array[k/N][k%N] % 2))
        {
            indPrevOdd = k;
            indFirstOdd = k;
            valPrevOdd = Array[k/N][k%N];
        }
        k++;
    }
    while(indPrevOdd == -1 && k != M*N);
    k = 0;
    //Находим первое чётное число и принимаем его за максимум.
    do
    {
        if(!(Array[k/N][k%N] % 2))
        {
            indPrevEven = k;
            indFirstEven = k;
            valPrevEven = Array[k/N][k%N];
        }
        k++;
    }
    while (indPrevEven == -1 && k != M*N);
    //Основной цикл. Сортировка осуществляется методом пузырька.
    IterIs= 1; //Признак того, что была осуществлена хотя бы одна перестановка.
    while (IterIs)
    {
        IterIs = 0;
        indPrevEven = indFirstEven;
        valPrevEven = Array[indFirstEven/N][indFirstEven%N];
        indPrevOdd = indFirstOdd;
        valPrevOdd = Array[indFirstOdd/N][indFirstOdd%N];
        for(int i = 0; i < M*N; i++)
        {
            int value = Array[i/N][i%N];
            if (value % 2)
            {
                //Нечетное.
                if(value < valPrevOdd)
                {
                    Array[i/N][i%N] = valPrevOdd;
                    Array[indPrevOdd/N][indPrevOdd%N] = value;
                    IterIs = 1;
                }
                indPrevOdd = i;
                valPrevOdd = Array[i/N][i%N];
            }
            else
            {
                //Чётное.
                if(value > valPrevEven)
                {
                    Array[i/N][i%N] = valPrevEven;
                    Array[indPrevEven/N][indPrevEven%N] = value;
                    IterIs = 1;
                }
                indPrevEven = i;
                valPrevEven = Array[i/N][i%N];
            }
        }
    }
    cout << endl;
    PrintArray(Array);
    return 0;
}
0
0 / 0 / 0
Регистрация: 14.12.2009
Сообщений: 11
12.03.2010, 20:47  [ТС] 3
большое спасибо,товарищ
думаю это одно и то же
0
12.03.2010, 20:47
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.03.2010, 20:47
Помогаю со студенческими работами здесь

Даны квадратная матрица A порядка n и вектор с n элементами. Получить вектор: (A=E)b, где E единичная матрица порядка n
Даны квадратная матрица A порядка n и вектор с n элементами. Получить вектор: (A=E)b, где...

Определить базовый класс "Матрица" и класс-потомок "Треугольная матрица"
Нужно определить класс &quot;матрица&quot; с возможностью динамического выделения и освобождения памяти,...

матрица
. Задана матрица С(N,M) N&lt;=15, M&lt;=20. Отпечатать номера строк матрицы С, первый и последний...

Матрица М * М
Определить с помощю функции совместимость матрицы размерности М * М относительно главной диагонали....


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru