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

Зеркально отразить элементы матрицы относительно главной диагонали - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Неплоский класс http://www.cyberforum.ru/cpp-beginners/thread573740.html
Что есть такое неплоский класс? Класс в котором используется динамическая память?
C++ ошибка в процедуре вставки в упор. массив void insert (int a,int &n,int x) { int i=n; int j=n+1; while (a>x) a=a; a=x; if (j!=0) while (j>=0) a=a; n=n+1; http://www.cyberforum.ru/cpp-beginners/thread573728.html
C++ Крестики нолики на С++
Помогите плиз, нужны крестики нолики на С++, поле 3 на 3, передвигаться стрелочками, минименю.
Хэш-таблицы C++
Добавить функцию Scan просмотра таблицы (в случае цепочек –элементы списка выводить на одной строке, через табуляцию), функцию расчета коэффициента заполнения хэш-таблицы ( альфа=n/m - число хранимых элементов /размер массива хэш). Использовать функции при моделировании. Провести исследования построения хэш-таблиц для разного размера (например 16,32 или 32,64, 128) с коллизиями. Исследовать...
C++ Бинарные деревья http://www.cyberforum.ru/cpp-beginners/thread573703.html
Доброго времени суток, нужна помощь, дали задание...Вершина бинарного дерева содержит ключ, строку и два указателя на потомков.Составить функцию распечатки всех элементов дерева по уровням: корень дерева, вершины 1-го уровня, вершины 2-го уровня, ... Есть мысли как реализовать?...
C++ Как решить без массивов? как это решить без массивов? //--------------------------------------------------------------------------- #include <vcl.h> #pragma hdrstop //--------------------------------------------------------------------------- #include <iostream> #include <ctime> using namespace std; подробнее

Показать сообщение отдельно
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
14.05.2012, 01:55     Зеркально отразить элементы матрицы относительно главной диагонали
ну да. там при первой итерации идет выход за пределы массива С[m-0+1][m-0+1]
Вот попробуйте:
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
#include <iostream>
#include <time.h>
#include <stdlib.h>
 
using namespace std;
int main()
{ 
    setlocale(LC_ALL, "");
    srand(time(NULL));
    int m = 3;
    //cout<<"Введите размер матрицы M: "; cin>>m;
 
    int **C = new int*[m],i,j;
    cout<<"Исходная матрица равна: "<<endl;
    for (i=0;i<m;i++)
    {
        *(C+i)=new int[m];
        for (j=0;j<m;j++)
        {
            *(*(C+i)+j)=rand()%21;
            cout<<*(*(C+i)+j)<<"\t";
        }
        cout<<endl;
    }
 
    // тут првда диагональные элементы тоже как бы отображаются. если хочется оптимизировать
    // то проход нужно долеть от второго до последнего в первом цикле и от нуля до i-1 во втором.
    for(i=0; i < m; ++i)
    {
        for(j=0; j < i; ++j)
        {
            const int x=C[i][j];
            C[i][j]=C[j][i];
            C[j][i]=x;
        }
    }
     /*
    // вот так:
    for(i=1; i < m; ++i)
    {
        for(j=0; j < i-1; ++j)
        {
            const int x=C[i][j];
            C[i][j]=C[j][i];
            C[j][i]=x;
        }
    }
    */
    
 
    cout << "!!!!!!!!!!!" << endl;
    for(i=0; i<m; ++i)
    {
        for(j=0; j<m; ++j)
        {
            cout<<C[i][j]<<"\t";
        }
        cout<<endl;
    } 
 
    return 0;
}
 
Текущее время: 03:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru