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

массивы - C++

Восстановить пароль Регистрация
 
юля2010
7 / 0 / 1
Регистрация: 06.12.2010
Сообщений: 12
11.12.2010, 19:41     массивы #1
Помогите пожалуйста написать на Си
В заданной целочисленной матрице поменять местами столбцы,
содержащие минимальный и максимальный элементы матрицы.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.12.2010, 19:41     массивы
Посмотрите здесь:

Циклические массивы;Многомерные массивы!!!Срочно бы) C++
Одномерные массивы, Работа со строками, Многомерные массивы. C++
C++ Попадание точки. Массивы чисел. Массивы записей.
Целочисленная арифметика ,Одномерные массивы ,Двумерные массивы C++
Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц) C++
C++ Двумерные массивы(массивы указателей на массивы)
C++ Массивы. Циклические алгоритмы (Заполнить массивы случайными числами, лежащими в интервале 0 до 100)
C++ Многомерные массивы и массивы символьной строки

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MILAN
 Аватар для MILAN
883 / 777 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 19:50     массивы #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
61
62
63
64
65
66
#include <iostream>
#include <ctime>
#include <iomanip>
 
using namespace std;
 
int main()
{
        srand(static_cast<int>(time(NULL)));
        int **arr;
        int M,N,st_max=0,st_min=0,temp=0,max,min;
        cout<<"Enter M: ";
        cin>>M;
        cout<<"Enter N: ";
        cin>>N;
        arr = new int*[M];
        cout<<endl<<"Matrix: "<<endl;
        for(int i=0; i<M; i++)
        {
              arr[i]=new int[N];
              for(int j=0; j<N; j++)
                {
                    arr[i][j]=rand()%10-1;
                    cout<<setw(3)<<arr[i][j]<<setw(3);
                }
          cout<<endl;
        }
     max=arr[0][0];
     min=arr[0][0];
     for(int i=0; i<M; i++)
        {  
              for(int j=0; j<N; j++)
                {
                   if(arr[j][i]>max)
                     {
                       max=arr[j][i];
                       st_max=i;
                     }
                   if(arr[j][i]<min)
                     {
                       min=arr[j][i];
                       st_min=i;
                     }
              }
        for(int i=0; i<M; i++)
                {
                       temp=arr[i][st_max];
                       arr[i][st_max]=arr[i][st_min];
                       arr[i][st_min]=temp;
                }
           }
         cout<<endl<<"New matrix: "<<endl;
        for(int i=0; i<M; i++)
        {
              for(int j=0; j<N; j++)
                {
                  cout<<setw(3)<<arr[i][j]<<setw(3);
                }
          cout<<endl;
        }
         for(int i=0; i<M; i++)
           delete arr[i];
             delete [] arr;
   system("pause");
   return 0;
}
fasked
Эксперт C++
 Аватар для fasked
4924 / 2504 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
11.12.2010, 20:02     массивы #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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <stdio.h>
#include <stdlib.h>
 
#define ROWS 5
#define COLS 5
 
int main()
{
        int i = 0;
        int j = 0;
 
        int buf = 0;
 
        int min = 0;
        int max = 0;
 
        int mincol = 0;
        int maxcol = 0;
 
        int matrix[ROWS][COLS];
 
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j)
                        matrix[i][j] = rand() % 99;
        }
 
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j)
                        printf("%2d ", matrix[i][j]);
 
                printf("\n");
        }
 
        min = matrix[0][0];
        max = matrix[0][0];
 
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j) {
                        if(max < matrix[i][j]) {
                                max = matrix[i][j];
                                maxcol = j;
                        }
                        if(min > matrix[i][j]) {
                                min = matrix[i][j];
                                mincol = j;
                        }
                }
        }
 
        if(mincol != maxcol) {
                for(i = 0; i < ROWS; ++i) {
                        buf = matrix[i][mincol];
                        matrix[i][mincol] = matrix[i][maxcol];
                        matrix[i][maxcol] = buf;
                }
        }
 
        printf("\n");
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j)
                        printf("%2d ", matrix[i][j]);
 
                printf("\n");
        }
 
        return 0;
}
Yandex
Объявления
11.12.2010, 20:02     массивы
Ответ Создать тему
Опции темы

Текущее время: 23:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru