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

матрица - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Написать функцию, проверяющую является ли введенная строка палиндромом http://www.cyberforum.ru/cpp-beginners/thread103665.html
Помогите пожалуйста. Реализовать функцию, которая принимает строку и возвращает истину, если строка является палиндромом.
C++ округлить элементы массива X(m) до ближайшего целого ПАРНИ ,ПОМОГИТЕ ПОЖАЛУЙСТА! Напишите кто может текст программы . 1 задача Поменять местами наибольший и наименьший элемент массива T(m) 2 задача в массиве X(m) найти общее число элементов до первого и после последнего нулевых элементов. 3 задача Сколько элементов в массиве X(m) после второго нулевого элемента. 4 задача Из элементов массивов X(m) и Y(m) образовать массив... http://www.cyberforum.ru/cpp-beginners/thread103656.html
Что работает быстрее? C++
Подскажите пожалуйста, какая из данных реализаций будет работать бытрее? int a = 5; int b = 3; int c = 4; int d,e,f; //эта d = a+b;
C++ Перевести в C++
type TLong2=array of longint; TLong2x2=array of TLong2; const Delta=$9E3779B9; var key:TLong2x2; procedure EnCryptRouting(var data); var y,z,sum:longint; a:byte; begin y:=TLong2(data);z:=TLong2(data);sum:=0; for a:=0 to 31 do
C++ СЛАУ http://www.cyberforum.ru/cpp-beginners/thread103568.html
Всем привет!!! Помогите пожалуйста переделать программу, чтобы она выбирала главный элемент не по строке, а по столбцу!!! Пожалуйста..... ))) #include "stdafx.h" #include <iostream> #include <math.h> using namespace std; void PrMass(float mass); void Delenie(float mass, int n, int m);
C++ Работа с консолью Есть консоль которая вызывается в DLL таким кодом AllocConsole();; 1) Как можно писать ней разноцветным шрифтом отдельные слова? 2) Как использовать звуки ? 3) Как изменить размер окна консоли ? 4) Как очистить консоль от записей ? 5) Как использовать графику? подробнее

Показать сообщение отдельно
Sanych.by
3 / 3 / 1
Регистрация: 01.03.2010
Сообщений: 3
12.03.2010, 19:48     матрица
Если распределить в Вашем понимании это упорядочить, не меняя расположения чётных и нечётных элементов, то вот код:

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