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

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

Войти
Регистрация
Восстановить пароль
 
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 150
#1

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

23.09.2013, 09:57. Просмотров 813. Ответов 8
Метки нет (Все метки)

Доброго времени суток.
Помогите пож-ста.
Условие с++:

Квадратная матрица M, состоящая из целых чисел, вводится с клавиатуры. Определить, является ли она магическим квадратом, т.е. такой, в которой суммы элементов во всех строках и столбцах одинаковы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.09.2013, 09:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Магический квадрат матрицы (C++):

Магический квадрат - C++
Всем привет! Вот во вторник экзамен по программированию, препод дала задачки разобрать пять штук, для подготоки, помогите если не сложно. ...

Магический квадрат - C++
Опишу проблему, первая лаба по Си++, в прошлом году был просто Си, в Си немного понимаю, а теперь прога которую над сделать, ну не...

Магический квадрат - C++
прошу помочь в такой схеме решения магического квадрата. #include <iostream> using namespace std; #include <Windows.h> #include...

Магический квадрат - C++
Задана матрица целых чисел. Определить является ли она магическим квадратом, т.е. такой, в которой суммы элементов во всех строках и...

Магический квадрат - C++
с клавы вводиться число N. нужно сделать магический квадрат с размерами

Магический квадрат - C++
Задача: Написать программу, которая определяет, явдяется ли заданная целочисленная квадратная матрица порядка N 'магическим квадратом',...

8
newyork7776
349 / 342 / 80
Регистрация: 21.05.2013
Сообщений: 1,311
Завершенные тесты: 1
23.09.2013, 11:07 #2
а диагонали брать?
0
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 150
23.09.2013, 11:18  [ТС] #3
Да.
0
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;
}
1
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 за ненадобностью.
1
Миниатюры
Магический квадрат матрицы  
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 150
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;
}
0
Миниатюры
Магический квадрат матрицы  
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 150
24.09.2013, 10:55  [ТС] #7
Хочу всем сказать большое спасибо.
Именно такая программа и была нужна.
А может кто нибудь ещё в этом же коде, реализовать перегрузку функций для массивов целого, вещественного, символьного типа. ???
А то лекции по этому всему не было. Лабу дали на дом.
В методичке смотрел, без примера не понятно.
0
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 брейки можно убрать.
1
Zumuist
2 / 2 / 0
Регистрация: 23.09.2013
Сообщений: 150
25.09.2013, 07:54  [ТС] #9
оК. Разобрался. Большое спасибо.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.09.2013, 07:54
Привет! Вот еще темы с ответами:

Магический квадрат) - C++
Определить, является ли заданная квадратная матрица порядка n магическим квадратом, т.е. матрицей, у которой суммы элементов строк и...

Магический квадрат - C++
можно составить магический квадрат с первых 36 простых чисел? (сумма элементов которой в каждой срок, в каждом столбцы и по каждой...

Магический квадрат, предикаты - C++
Доброе время суток, господа. Молю вас о помощи. Есть сие задание: Составить программу для решения одной из следующих задач....

Задача.Магический квадрат. - C++
Хочу решить задачу. http://atpp.vstu.edu.ru/cgi-bin/arh_problems.pl?id_prb=994. Подскажите по какому принципу действовать? С чего...


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

Или воспользуйтесь поиском по форуму:
9
Yandex
Объявления
25.09.2013, 07:54
Ответ Создать тему
Опции темы

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