С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.75
Дмитрий 93
74 / 59 / 5
Регистрация: 03.06.2011
Сообщений: 309
#1

Поменять местами столбцы в массиве - C++

27.06.2012, 20:55. Просмотров 2620. Ответов 8
Метки нет (Все метки)

Дан массив размером nxn, насколько я понял динамический. Если количество стобцов четное то поменять столбцы по правилу: первый со вторым, третий с четвертым и так далее. Если количество столбцов нечетное то оставить матрицу без изменений
с динамическими массивами у меня трудно, поэтому сделал по шаблону код, поставил условие четности. при запуске ввожу элементы, массив выводится на экран, а столбцы местами не меняются, а при вводе размерности больше чем 3 винда ошибку показывает. где что исправить?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<iostream>//
int **creat(int &n)
{ cout<<"n="; cin>>n;
int **mas=new int *[n];
for(int j=0; j<n; ++j) mas[j]=new int[n];
for(int i=0; i<n; ++i)
for(int j=0; j<n; ++j) { cout<<"mas["<<i<<"]["<<j<<"]="; cin>>mas[i][j]; } 
return mas; }
int main()
{ int n;
cout<<"n="; cin>>n;
int **a=creat(n);
int *z;
if(n%2==0)
for(int j=0; j<n; j++)
{ z=a[j]; a[j]=a[j+1]; j+=2; }
for(int i=0; i<n; ++i, cout<<endl)
for(int j=0; j<n; ++j) cout<<a[i][j]<<"\t";
for(int j=0; j<n; ++j) delete [] a[j];
delete[]a; 
return 0;}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.06.2012, 20:55
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Поменять местами столбцы в массиве (C++):

Поменять местами столбцы в массиве - C++
В массиве a поменять местами 1 и 3 столбец. Исходный и получившийся массив вывести в виде матрицы. Заранее спасибо.

Поменять местами столбцы в динамическом массиве - C++
Нужно переставить местами столбцы в динамическом массиве по ключу! У меня почему-то переставляет на правильно, не могу найти ошибку,...

Как поменять местами столбцы в двумерном динамическом массиве? - C++
нужно столбцы с четными номерами поменять местами с нечетными, помогите исправить ошибку int main() { setlocale(LC_ALL, &quot;Russian&quot;); ...

В двумерном массиве поменять местами столбцы, симметричные относительно середины массива - C++
Кто чем может.Новичок ,только учусь 3.В двумерном массиве целых чисел поменять местами столбцы, симметричные относительно середины...

поменять столбцы местами по правилу - C++
Помогите пожалуйста составить программу!!!! дан массив размером nxn , элементы которого целые числа. Если кол-во столбцов в массиве...

Поменять местами столбцы матрицы - C++
условие : В матрице из действительных чисел поменять местами последний столбец со столбцом, содержащим наибольшее по абсолютной величине...

8
g-h
67 / 67 / 1
Регистрация: 03.06.2012
Сообщений: 176
27.06.2012, 21:05 #2
Цитата Сообщение от Дмитрий 93 Посмотреть сообщение
for(int j=0; j<n; j++)
{ z=a[j]; a[j]=a[j+1]; j+=2; }
Здесь у вас переменная j сначала внутри цикла меняется(j += 2) а потом еще и после окончания цикла увеличивается на 1
C++
1
2
3
4
for (int j=0; j<n; j += 2)
{
   ...
}
Размер массива почему-то два раза вводится. В main() и в creat()
0
Севак
любитель покушать
682 / 633 / 106
Регистрация: 25.09.2011
Сообщений: 1,313
27.06.2012, 21:07 #3
как менять столбцы/строки местами
для данного случая, создается одномерный массив размером n, производится действие
C++
1
2
3
a[0]=b[0][0];
b[0][0]=b[1][0];
b[1][0]=a[0];
0
Дмитрий 93
74 / 59 / 5
Регистрация: 03.06.2011
Сообщений: 309
27.06.2012, 21:12  [ТС] #4
Цитата Сообщение от g-h Посмотреть сообщение
Здесь у вас переменная j сначала внутри цикла меняется(j += 2) а потом еще и после окончания цикла увеличивается на 1
C++
1
2
3
4
for (int j=0; j<n; j += 2)
{
   ...
}
Размер массива почему-то два раза вводится. В main() и в creat()
фрагмент кода изменил,

C++
1
2
3
if(!n%2)
 for(int j=0; j<n; j+=2)
{ z=a[j]; a[j]=a[j+1]; }
столбцы местами все равно не меняются
0
g-h
67 / 67 / 1
Регистрация: 03.06.2012
Сообщений: 176
27.06.2012, 21:28 #5
C++
1
2
3
4
5
6
7
8
9
10
    if (n%2==0)
    {
        for (int i=0; i<n; i += 2)
            for (int j=0; j<n; j++)
            {
                z = a[j][i];
                a[j][i] = a[j][i+1];
                a[j][i+1] = z;
            }
    }
0
David Sylva
1291 / 953 / 51
Регистрация: 17.05.2012
Сообщений: 2,687
27.06.2012, 21:36 #6
Вот как-то так можно сделать

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
#include <iostream> 
#include <ctime> 
#include <cstdlib> 
#include <iomanip> 
using namespace std; 
int main() 
{   
    setlocale(0, "rus");
    srand((unsigned) time(0));
    int x, y;  
    int i,j;
 
    cout << "Введите количество строк " << endl; 
    cin >> x; 
    cout << "Введите количество столбцов " << endl; 
    cin >> y;
 
    int** array; // динамически выделяем память
 
    array = new int*[x]; 
 
    for ( i = 0; i < y; i++) 
        array[i] = new int [y]; 
 
    for ( i = 0; i < x; i++)  // заполняем случайными числами
        for ( j = 0; j < y; j++) 
            array[i][j] = rand() % 100; 
 
    for ( i = 0; i < x; i++)  // выводим исходную матрицу
        for ( j = 0; j < y; j++) 
        { 
            if( j % y == 0) 
                cout << endl; 
            cout << setw(3) << array[i][j]; 
        } 
        cout << endl;  
 
        if( y % 2 == 0)  // если чётно меняем местами
        {
 
            for ( j = 0; j < y; j++)  
            {
                for ( i = 0; i < x; i++) 
                { 
                    int temp = array[i][j]; 
                    array[i][j] = array[i][j+1]; 
                    array[i][j+1] = temp;  
                }  
                j++;
                
            } 
 
 
            for ( i = 0; i < x; i++) // выводим отсортированную
        for ( j = 0; j < y; j++) 
        { 
            if( j % y == 0) 
                cout << endl; 
            cout << setw(3) << array[i][j]; 
        } 
        cout << endl;   
        } 
 
        else  // иначе выводи исходную
        {
            for ( i = 0; i < x; i++) 
        for ( j = 0; j < y; j++) 
        { 
            if( j % y == 0) 
                cout << endl; 
            cout << setw(3) << array[i][j]; 
        } 
        cout << endl;   
        }   
 
        delete array;
}
2
Дмитрий 93
74 / 59 / 5
Регистрация: 03.06.2011
Сообщений: 309
27.06.2012, 22:04  [ТС] #7
Цитата Сообщение от David Sylva Посмотреть сообщение
Вот как-то так можно сделать

C++
1
2
3
4
#include <iostream> 
#include <ctime> 
#include <cstdlib>
#include <iomanip>
я так понял cstdlib это для выбора рандомных чисел, да? а ctime для чего?
0
g-h
67 / 67 / 1
Регистрация: 03.06.2012
Сообщений: 176
27.06.2012, 22:10 #8
ctime вроде чтобы можно было использовать функцию time(0)
C++
1
srand((unsigned) time(0));
1
David Sylva
1291 / 953 / 51
Регистрация: 17.05.2012
Сообщений: 2,687
27.06.2012, 22:12 #9
ctime для time(), а rand() и srand() определены в cstdlib
1
27.06.2012, 22:12
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.06.2012, 22:12
Привет! Вот еще темы с ответами:

Как поменять столбцы местами - C++
Имеется матрица 3 на 3, нужно поменять её столбцы так что бы они стояли по убиваюнию их поэлементных сумм. Сумму нашел, а как их...

Поменять местами 2-й и 3-й столбцы матрицы - C++
Есть код, он меняет главную диагональ. А нада поменять 2-й и 3-й столбцы местами. Помогите переделать. #include&lt;iostream&gt; using...

Поменять местами в матрице i-й и j-й столбцы - C++
Даны натуральные числа i, j, вещественная матрица размера M x N. Поменять местами в матрице i-й и j-й столбцы.

Поменять местами столбцы матрицы - C++
Дано действительную квадратную матрицу порядка N. Поменять местами столбик, в котором находится максимальный элемент матрицы со...


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

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

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