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

Магический квадрат матрицы - C++

Восстановить пароль Регистрация
 
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 149
23.09.2013, 09:57     Магический квадрат матрицы #1
Доброго времени суток.
Помогите пож-ста.
Условие с++:

Квадратная матрица M, состоящая из целых чисел, вводится с клавиатуры. Определить, является ли она магическим квадратом, т.е. такой, в которой суммы элементов во всех строках и столбцах одинаковы.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.09.2013, 09:57     Магический квадрат матрицы
Посмотрите здесь:

Магический квадрат C++
Магический квадрат C++
Магический квадрат) C++
C++ Магический квадрат
C++ Магический квадрат
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
newyork7776
 Аватар для newyork7776
346 / 339 / 79
Регистрация: 21.05.2013
Сообщений: 1,305
Завершенные тесты: 1
23.09.2013, 11:07     Магический квадрат матрицы #2
а диагонали брать?
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 149
23.09.2013, 11:18  [ТС]     Магический квадрат матрицы #3
Да.
behemoth
 Аватар для behemoth
44 / 30 / 7
Регистрация: 29.09.2012
Сообщений: 75
Записей в блоге: 1
24.09.2013, 01:49     Магический квадрат матрицы #4
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
#include <iostream>
 
using namespace std;
 
int sum_d(int**,int,bool);//sum diagonal
int sum_(int**,int,int,bool);//sum rows and cols
int main(){
    int size=10;
    cout<<"enter plz size of array:";
    cin>>size;
    int **arr = new int*[size];
    for(int i=0;i<size;i++){
        arr[i] = new int[size];
    }
    
    /*init array*/
    for(int i=0;i<size;i++){
        for(int j=0;j<size;j++){
            cout<<"arr["<<i<<"]["<<j<<"]=";
            cin>>arr[i][j];
        }
    }
    cout<<"\nprint_array:\n";
    for(int i=0;i<size;i++){
        for(int j=0;j<size;j++){
            cout<<arr[i][j]<<" ";
        }
        cout<<endl;
    }
    int temp = sum_d(arr,size,true);
    if(temp!=sum_d(arr,size,false)){
        cout<<"it's not magic";
    }else{
        for(int i=0;i<2*size;i++){
                if(i<size){
                        if(sum_(arr,size,i,true)!=temp){
                                cout<<"it's not magic";
                                break;
                        }
                }else{
                        if(sum_(arr,size,i-size,false)!=temp){
                                cout<<"it's not magic";
                                break;
                        }
                }
        }
        cout<<"holy shit,it is a real magic!!";
    }
    /*free allocate memory*/
    for(int i=0;i<size;i++){
        delete arr[i];
    }
    delete []arr;
return 0;
}
 
int sum_d(int **arr,int size,bool flag){
    int sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][i];
        }else{
            sum+=arr[i][size-i-1];
        }
    }
    return sum;
}
int sum_(int **arr,int size,int n,bool flag){
    int sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][n];
        }else{
            sum+=arr[n][i];
        }
    }
    return sum;
}
lipnev
60 / 60 / 1
Регистрация: 14.09.2013
Сообщений: 145
24.09.2013, 06:41     Магический квадрат матрицы #5
behemoth, работает, но выводит вот такой результат (см. снимок). Надо чуток подправить. После каждой строчки
C++
1
cout<<"it's not magic";
добавить
C++
1
return 0;
и убрать, соответственно break за ненадобностью.
Миниатюры
Магический квадрат матрицы  
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 149
24.09.2013, 10:51  [ТС]     Магический квадрат матрицы #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
78
79
80
81
82
83
84
85
#include <iostream>
 
using namespace std;
 
int sum_d(int**,int,bool);//sum diagonal
int sum_(int**,int,int,bool);//sum rows and cols
int main(){
    int size=10;
    cout<<"razmer mas:";
    cin>>size;
    int **arr = new int*[size];
    for(int i=0;i<size;i++){
        arr[i] = new int[size];
    }
 
    /*init array*/
    for(int i=0;i<size;i++){
        for(int j=0;j<size;j++){
            cout<<"mas["<<i<<"]["<<j<<"]=";
            cin>>arr[i][j];
        }
    }
    cout<<"\mas:\n";
    for(int i=0;i<size;i++){
        for(int j=0;j<size;j++){
            cout<<arr[i][j]<<" ";
        }
        cout<<endl;
    }
    int temp = sum_d(arr,size,true);
    if(temp!=sum_d(arr,size,false)){
        cout<<"it's not magic";
        system("pause");
        return 0;
    }else{
        for(int i=0;i<2*size;i++){
                if(i<size){
                        if(sum_(arr,size,i,true)!=temp){
                                cout<<"it's not magic";
                                 system("pause");
                                return 0;
                                break;
                        }
                }else{
                        if(sum_(arr,size,i-size,false)!=temp){
                                system("pause");
                                return 0;
                                break;
                        }
                }
        }
        cout<<" is a real magic!!";
    }
    /*free allocate memory*/
    for(int i=0;i<size;i++){
        delete arr[i];
    }
    delete []arr;
  system("pause");
return 0;
}
 
int sum_d(int **arr,int size,bool flag){
    int sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][i];
        }else{
            sum+=arr[i][size-i-1];
        }
    }
 
    return sum;
}
int sum_(int **arr,int size,int n,bool flag){
    int sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][n];
        }else{
            sum+=arr[n][i];
        }
    }
    return sum;
}
Миниатюры
Магический квадрат матрицы  
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 149
24.09.2013, 10:55  [ТС]     Магический квадрат матрицы #7
Хочу всем сказать большое спасибо.
Именно такая программа и была нужна.
А может кто нибудь ещё в этом же коде, реализовать перегрузку функций для массивов целого, вещественного, символьного типа. ???
А то лекции по этому всему не было. Лабу дали на дом.
В методичке смотрел, без примера не понятно.
behemoth
 Аватар для behemoth
44 / 30 / 7
Регистрация: 29.09.2012
Сообщений: 75
Записей в блоге: 1
24.09.2013, 23:18     Магический квадрат матрицы #8
можно вот так перегрузить для инта(так же и для чара можно):
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
int sum_d(int **arr,int size,bool flag){
    return (int)sum_d((double**)arr,size,flag);
}
int sum_(int **arr,int size,int n,bool flag){
    return (int)sum_((double**)arr,size,n,flag);
}
double sum_d(double **arr,int size,bool flag){
    double sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][i];
        }else{
            sum+=arr[i][size-i-1];
        }
    }
 
    return sum;
}
double sum_(double **arr,int size,int n,bool flag){
    double sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][n];
        }else{
            sum+=arr[n][i];
        }
    }
    return sum;
}
а можно юзать шаблоны:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
template <typename T> T sum_d(T **arr,int size,bool flag){
    T sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][i];
        }else{
            sum+=arr[i][size-i-1];
        }
    }
 
    return sum;
}
template <typename T> T sum_(T **arr,int size,int n,bool flag){
    T sum=0;
    for(int i=0;i<size;i++){
        if(flag){
            sum+=arr[i][n];
        }else{
            sum+=arr[n][i];
        }
    }
    return sum;
}
+ кстати для system("pause") нужно заинклудить stdlib.h и это Сишна либа, и после return'a брейки можно убрать.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.09.2013, 07:54     Магический квадрат матрицы
Еще ссылки по теме:

C++ Магический квадрат
Магический квадрат C++
Магический квадрат C++

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

Или воспользуйтесь поиском по форуму:
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 149
25.09.2013, 07:54  [ТС]     Магический квадрат матрицы #9
оК. Разобрался. Большое спасибо.
Yandex
Объявления
25.09.2013, 07:54     Магический квадрат матрицы
Ответ Создать тему
Опции темы

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