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

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

Войти
Регистрация
Восстановить пароль
 
Ruslanishe
25 / 9 / 1
Регистрация: 17.10.2010
Сообщений: 203
#1

Можно ли расположить на побочной диагонали элементы так, чтобы они возрастали - C++

09.11.2011, 19:32. Просмотров 584. Ответов 3
Метки нет (Все метки)

Здравствуйте, форумчане! вот такая у меня задачка:
Задан двумерный массив N x N. Разрешается произвольно переставлять элементы внутри любого столбца. Проверить, можно ли выполнив конечное количество перестановок в столбцах, расположить на побочной диагональ элементы так, чтобы он возрастали.

Я вот попробовал её сделать, только у меня не получается переставить элементы в побочной диагонали по возрастанию! Помогите чем сможете!

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
#include <iostream>
#include <ctime>
#include <conio.h>
using namespace std;
 
const int N = 3;
void vvod( int mass[N][N] )
{
    srand(time(NULL));
    for (int i=0; i<N; i++)
    {
        for(int j=0; j<N; j++)
        {
                mass[i][j] = rand() % 100;
        }
    }
     
}
 
void vivod( int mass[N][N] )
{
     for (int i=0; i<N; i++)
     {
         for(int j=0; j<N; j++)
         {
                 cout << mass[i][j] << " ";
         }
         cout << endl;
     }  
}
  
int findMaxElement( int mass[N][N] )
{
        int maxElement;
        int maxi = 0; 
        int maxj = 0;
        
        for ( int i = 0; i < N; i++ )
        {     
               maxElement = 0; 
                for ( int j = 0; j < N; j++ )
                {
                        if ( ( mass[i][j] >= maxElement ) )
                        {       
                                maxElement = mass[i][j];
                                maxi = i;
                                maxj = j;
                        }
                
                }
                cout << "ГЊГ*ГЄГ±ГЁГ¬Г*ëüГ*ûé ýëåìåГ*ГІ Гў ñòðîêå - " << i << " = " << maxElement << endl;
                cout << "i = " << maxi << " " << "j = " << maxj << endl;
                int temp = mass[maxi][maxj];
                mass[maxi][maxj] = mass[i][N - 1 - i];
                mass[i][N - 1 - i] = temp;
        }
        
        
                
                   
}
 
void perestanovka( int mass[N][N] )
{
     
     for ( int i = N+1; i < 0; i-- )
        {
            for ( int j = 0; j < N+1; j++ )
            {
                if ( mass[i-1][j+1] > mass[i][j] )
                {
                     mass[i-1][j+1] = mass[i][j];
                }
            }
        }
}     
 
int main() 
{       
    int mass[N][N];
    setlocale(LC_CTYPE, "Russian" );
    vvod ( mass );
    vivod ( mass );
    cout << endl;
    findMaxElement( mass );
    cout << endl;
    vivod ( mass );    
    cout << endl;
    perestanovka ( mass );
    vivod ( mass );    
    
    getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.11.2011, 19:32
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Можно ли расположить на побочной диагонали элементы так, чтобы они возрастали (C++):

Расположить элементы матрицы так, чтобы на побочной диагонали были бы максимальные элементы строк - C++
Доброго времени суток. помогите пожалуйста с задачей последняя осталась) Расположить элементы матрицы M, так чтобы на побочной диагонали...

Переставить элементы в строках матрицы так, чтобы по диагонали они были упорядочены по возрастанию - C++
В данной задаче матрица – двумерный динамический массив, который считывается из некоторого текстового файла. Вектор – одномерный...

Составить массив B так, чтобы элементы массива A[0..6, 0..6] следовали в нем в последовательности диагоналей параллельно побочной диагонали - C++
Дали лабораторную работу по информатике Задание: Составить массив В так, чтобы элементы массива A следовали в нем в последовательности...

Даны точки на плоскости: расположить их так, чтобы они образовывали вершины выпуклого многоугольника - C++
На плоскости заданы N точек своими декартовыми координатами. Расположить эти точки в таком порядке, чтобы они образовывали вершины...

Перераспределить элементы массива так, чтобы они удовлетворяли условию - C++
дан массив a, сам ввожу члены этого массива перераспределить элементы массива так , чтобы они удовлетворяли условию ...

В двумерном массиве A[N][M] упорядочить строки так, что бы возрастали элементы заданного столбца. Массив статический - C++
Очень надо! Пожалуйста помогите!!!

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
DKOI
24 / 24 / 1
Регистрация: 08.09.2010
Сообщений: 136
09.11.2011, 19:48 #2
массив нельзя так передавать в функцию
Можно так
C++
1
void vivod( int ** mass )
При это объявлять как
C++
1
2
3
int ** mass = new int*[n];
for (int i = 0; i < n; i++)
    mass[i] = new int[n];
Ruslanishe
25 / 9 / 1
Регистрация: 17.10.2010
Сообщений: 203
09.11.2011, 19:55  [ТС] #3
Цитата Сообщение от DKOI Посмотреть сообщение
массив нельзя так передавать в функцию
Можно так
C++
1
void vivod( int ** mass )
При это объявлять как
C++
1
2
3
int ** mass = new int*[n];
for (int i = 0; i < n; i++)
    mass[i] = new int[n];
Я это не очень пока понимаю! далее буду изучать! У Вас есть предложения по моему вопросу?
Сета
Сообщений: n/a
14.11.2012, 00:59 #4
а как прописать тоже задание только на С #?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.11.2012, 00:59
Привет! Вот еще темы с ответами:

Расположить почтовые ящики так, чтобы народу на один было как можно меньше - C++
Дано N городов и Y почтовых ящиков, а также население. Нужно расположить почтовые ящики так, чтобы народу на 1 было как можно меньше(т.е...

Расположить элементы массива так, чтобы нули было в начале, а единицы в конце - C++
Дан массив, состоящий из нулей и единиц, нужно расположить элементы массива так, чтобы нули было в начале, а единицы в конце.

Переставить столбцы матрицы, чтобы элементы ее побочной диагонали образовали невозрастающую последовательность - C++
Переставьте столбцы вещественной квадратной матрицы так, чтобы элементы ее побочной диагонали образовали невозрастающую последовательность

Расположить элементы массива так, чтобы сначала были отрицательные и нули, а потом положительные - C++
Дан массив из 12 элементов. Расположить элементы так,чтобы сначала были отрицательные и нули,а потом положительные. Порядок расстановки не...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
14.11.2012, 00:59
Ответ Создать тему
Опции темы

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