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

"Обратить" матрицу - C++

Восстановить пароль Регистрация
 
Starstuck
 Аватар для Starstuck
4 / 4 / 0
Регистрация: 01.02.2012
Сообщений: 124
05.12.2012, 23:31     "Обратить" матрицу #1
"Обратить" любую(не квадратную) матрицу - поменять местами 1 и последний элементы, 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
#include <stdio.h>
#include <stdlib.h>
int n,m;
 
void swap(int **A, int **B)
{
     int ** temp;
     temp=A;
     A=B;
     B=temp;
}
 
 
int main()
{
    scanf("%d%d",&n,&m); // -ÑèòûâГ*ГҐГ¬ Г°Г*çìåðГ*îñòü Г¬Г*Г±Г±ГЁГўГ*
    
    int **A, i ,j ;
    
    // ââîäèì äèГ*Г*ìè÷åñêè äâóìåðГ*ûé Г¬Г*Г±Г±ГЁГў A  Г°Г*çìåðîì [n][m]
    A = (int **) malloc(n*sizeof(int *));
    for(i=0; i< n; i++) A[i] = (int *)malloc(m*sizeof(int));
    
    // Ñ÷èòûâГ*ГҐГ¬ Г±Г*ìó Г¬Г*òðèöó
    for (i=0;i<n;i++)
        for (j=0;j<m;j++)
            scanf("%d",&(A[i][j]));
 
   // "îáðГ*Г№Г*ГҐГ¬ Г¬Г*òðèöó"
   int k=n;
   int l=m;
   for (i=1;i<=n;i++)
   {
       for (j=1;j<=m;j++)
           {
               swap (A[i][j],A[k][l]);
               if ((i==k) & (j==l)) break;
               l=l-1;
           }
        l=m;
        k=k-1;
    }
}
Добавлено через 7 минут
Help
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.12.2012, 23:31     "Обратить" матрицу
Посмотрите здесь:

кто нибудь делал прогу на С++ "Эмулятор клавиш с промежутком времени между "нажатиями""?! C++
В одномерном массиве состоящим из "N" вещественных элементов вычислить сумму элемента массива с не четными "N" C++
C++ Заполнить матрицу "песочными часами"
Имеется строка "AAABBCCAA", нужно вывести на экран "3A2B2C2A", и так же сделать обратное действие C++
При сокращении "Фамилия Имя Отчество" к "Фамилия И.О." пропадают "И.О." C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
05.12.2012, 23:33     "Обратить" матрицу #2
Матрицу не правильно передаёшь в функцию.
BumerangSP
 Аватар для BumerangSP
4283 / 1405 / 121
Регистрация: 16.12.2010
Сообщений: 2,941
Записей в блоге: 3
05.12.2012, 23:35     "Обратить" матрицу #3
По идее, в функцию же нужно отдельные числа передавать, а не указатели на указатели. И temp тоже просто int.
Starstuck
 Аватар для Starstuck
4 / 4 / 0
Регистрация: 01.02.2012
Сообщений: 124
05.12.2012, 23:45  [ТС]     "Обратить" матрицу #4
Сделал, как вы сказали. =)
Теперь программа при выводе ИСКОМОГО массива зависает. Как быть? O_O

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
#include <stdio.h>
#include <stdlib.h>
int n,m;
 
void swap(int A, int B)
{
     int temp;
     temp=A;
     A=B;
     B=temp;
}
 
 
int main()
{
    scanf("%d%d",&n,&m); // -ÑèòûâГ*ГҐГ¬ Г°Г*çìåðГ*îñòü Г¬Г*Г±Г±ГЁГўГ*
    
    int **A, i ,j ;
    
    // ââîäèì äèГ*Г*ìè÷åñêè äâóìåðГ*ûé Г¬Г*Г±Г±ГЁГў A  Г°Г*çìåðîì [n][m]
    A = (int **) malloc(n*sizeof(int *));
    for(i=0; i< n; i++) A[i] = (int *)malloc(m*sizeof(int));
    
    // Ñ÷èòûâГ*ГҐГ¬ Г±Г*ìó Г¬Г*òðèöó
    for (i=0;i<n;i++)
        for (j=0;j<m;j++)
            scanf("%d",&(A[i][j]));
 
   // "îáðГ*Г№Г*ГҐГ¬ Г¬Г*òðèöó"
   int k=n;
   int l=m;
   for (i=1;i<=n;i++)
   {
       for (j=1;j<=m;j++)
           {
               swap (A[i][j],A[k][l]);
               if ((i==k) & (j==l)) break;
               l=l-1;
           }
        l=m;
        k=k-1;
    }
    
        for (i=0;i<n;i++)
        {for (j=0;j<m;j++)
            printf("%d",(A[i][j]));
        printf("\n");
        }
}
v.a.l.i.d
 Аватар для v.a.l.i.d
412 / 377 / 10
Регистрация: 21.09.2012
Сообщений: 913
06.12.2012, 00:00     "Обратить" матрицу #5
Цитата Сообщение от Starstuck Посмотреть сообщение
void swap(int A, int B)
{
int temp;
temp=A;
A=B;
B=temp;
}
Здесь никакого обмена не происходит. Меняются только локальные переменные
C++
1
2
3
4
5
6
7
void swap(int &A, int &B)
{
     int temp;
     temp=A;
     A=B;
     B=temp;
}
Цитата Сообщение от Starstuck Посмотреть сообщение
for (i=1;i<=n;i++)
{
for (j=1;j<=m;j++)
{
А здесь выходы за границу массива:
C++
1
2
3
4
for (i=0;i<n;i++)
   {
       for (j=0;j<m;j++)
           {
Добавлено через 1 минуту
Цитата Сообщение от Starstuck Посмотреть сообщение
int k=n;
int l=m;
C++
1
2
int k=n-1;
 int l=m-1;
Starstuck
 Аватар для Starstuck
4 / 4 / 0
Регистрация: 01.02.2012
Сообщений: 124
06.12.2012, 00:03  [ТС]     "Обратить" матрицу #6
V.A.L.I.D, Всё исправил,спасибо. Выводит ни пойми что.
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
#include <stdio.h>
#include <stdlib.h>
int n,m;
 
void swap(int &A, int &B)
{
     int temp;
     temp=A;
     A=B;
     B=temp;
}
 
 
int main()
{
    scanf("%d%d",&n,&m); // -ÑèòûâГ*ГҐГ¬ Г°Г*çìåðГ*îñòü Г¬Г*Г±Г±ГЁГўГ*
    
    int **A, i ,j ;
    
    // ââîäèì äèГ*Г*ìè÷åñêè äâóìåðГ*ûé Г¬Г*Г±Г±ГЁГў A  Г°Г*çìåðîì [n][m]
    A = (int **) malloc(n*sizeof(int *));
    for(i=0; i< n; i++) A[i] = (int *)malloc(m*sizeof(int));
    
    // Ñ÷èòûâГ*ГҐГ¬ Г±Г*ìó Г¬Г*òðèöó
    for (i=0;i<n;i++)
        for (j=0;j<m;j++)
            scanf("%d",&(A[i][j]));
 
   // "îáðГ*Г№Г*ГҐГ¬ Г¬Г*òðèöó"
   int k=n-1;
   int l=m-1;
   for (i=0;i<n;i++)
   {
       for (j=0;j<m;j++)
           {
               swap (A[i][j],A[k][l]);
               if ((i==k) & (j==l)) break;
               l=l-1;
           }
        l=m;
        k=k-1;
    }
    
        for (i=0;i<n;i++)
        {for (j=0;j<m;j++)
            printf("%d",(A[i][j]));
        printf("\n");
        }
}
v.a.l.i.d
 Аватар для v.a.l.i.d
412 / 377 / 10
Регистрация: 21.09.2012
Сообщений: 913
06.12.2012, 00:04     "Обратить" матрицу #7
Цитата Сообщение от Starstuck Посмотреть сообщение
if ((i==k) & (j==l)) break;
C++
1
if ((i==k) && (j==l)) break;
Starstuck
 Аватар для Starstuck
4 / 4 / 0
Регистрация: 01.02.2012
Сообщений: 124
06.12.2012, 00:07  [ТС]     "Обратить" матрицу #8
V.A.L.I.D, все равно выводит что-то странное :O
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.12.2012, 00:27     "Обратить" матрицу
Еще ссылки по теме:

C++ Ошибки в примере:"newline in constant"и"unexpected end of file while looking for precompiled header directive"
C++ Найти номер последней по порядку строки в матрице, содержащей наибольшее количество букв "ш", "щ"
Как в этой программе правильно вывести матрицу? а то она у меня "пляшет" C++

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

Или воспользуйтесь поиском по форуму:
v.a.l.i.d
 Аватар для v.a.l.i.d
412 / 377 / 10
Регистрация: 21.09.2012
Сообщений: 913
06.12.2012, 00:27     "Обратить" матрицу #9
Starstuck, Могу свой вариант предложить. Меняет первый столбей и последний, второй и предпоследний и т.д.)
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
#include "stdafx.h"
#include "iostream"
#include "ctime"
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    srand(time(NULL));
 
    const int ROWS=3, COLS=18; // количество строк и столбцов
    int A[ROWS][COLS];
    int tmp;
 
    for (int y=0; y<ROWS; y++)
    {
        for (int x=0; x<COLS; x++)
        {
            A[y][x] = rand() % 10;
            cout << A[y][x] << " ";
        }
        cout << endl;
    }
    cout << endl;
 
    // перестановка столбцов 0<->17 1<->16 2<->15 ... 
    for (int x=0; x<COLS/2; x++)
        for (int y=0; y<ROWS; y++)
        {
            tmp = A[y][x];
            A[y][x] = A[y][COLS-1-x];
            A[y][COLS-x-1] = tmp;
        }
 
    for (int y=0; y<ROWS; y++)
    {
        for (int x=0; x<COLS; x++)
            cout << A[y][x] << " ";
        cout << endl;
    }
    cout << endl;
 
    system("pause");
    return 0;
}
только заполняется она случайными числами

Добавлено через 10 минут
Цитата Сообщение от Starstuck Посмотреть сообщение
"Обратить" любую(не квадратную) матрицу
А в самой программе почему-то квадратная:
Цитата Сообщение от Starstuck Посмотреть сообщение
int **A,
Для какой матрице нужна программа?

Добавлено через 2 минуты

Не по теме:

все, понял

Yandex
Объявления
06.12.2012, 00:27     "Обратить" матрицу
Ответ Создать тему
Опции темы

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