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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Копирование дерева каталогов в несколько потоков http://www.cyberforum.ru/cpp-beginners/thread1107271.html
Есть задача скопировать дерево каталогов в несколько потоков,количество потоков равно количеству количеству каталогов,средство синхронизации семафор. Синхронизировать вывод в терминал скопированных каталогов и файлов. Проблема в том что никогда подобное не делал ,подскажите пожалуйста в чем работать ,какие-нибудь простые примеры чтобы можно было понять. Теорию про средства синхронизации читал....
C++ Подправьте код, чтобы норм компилировался, просто у меня старый источник примеров по C++ Подправьте код, чтобы норм компилировался, просто у меня старый источник примеров по C++ #include <iostream> #include <conio.h> #include <string.h> using namespace std; class book { public: book (char*, char*, char*); http://www.cyberforum.ru/cpp-beginners/thread1107267.html
Дана матрица B(8,5). Составить массив, содержащий произведения элементов строки матрицы? C++
Вот я сделал - это дана матрица A(5,6). Составить массив содержащий минимальные элементы каждого столбца. А как переделать в - Дана матрица B(8,5). Составить массив, содержащий произведения элементов строки матрицы? Помогите ребят) #include <iostream> #include <conio.h> using namespace std; int A = {
C++ Оставить только то что после разделителя (знака = )
Здравствуйте, есть файл с кучей мусора и небольшими крупицами нужной информации, которая находится после знака = и начинается обязательно на число пример: IdMerchant=532541837 CARD_TYPE=CB numCarte=4970402011238561 EXPIRATION_MONTH=8 EXPIRATION_YEAR=2015 codeSecurite=912 birthday= LASTNAME=MALARD FIRSTNAME=PIERRE
C++ Класс Quadrangle (четырехугольник). Класс хранит Декартовы координаты четырех углов четырехугольника http://www.cyberforum.ru/cpp-beginners/thread1107208.html
Класс Quadrangle (четырехугольник). Класс хранит Декартовы координаты четырех углов четырехугольника. Конструктор принимает четыре группы координат. Должны быть предусмотрены функции-элементы, вычисляют периметр и площадь, а также функция, проверяет переданные координаты определяют прямоугольник. Длиной должно считаться более из двух измерений.
C++ Удалить из массива целых чисел все элементы, являющиеся простыми числами Люди, для кого не составит большого труда, напишите пожалуйста программу по поставленной задаче : Удалить из массива целых чисел все элементы, являющиеся простыми числами. Если можно как нибудь попроще чтобы я смог разобраться. Заранее спасибо. подробнее

Показать сообщение отдельно
Aer_rus
0 / 0 / 0
Регистрация: 13.10.2013
Сообщений: 91

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

28.02.2014, 00:31. Просмотров 1234. Ответов 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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#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;
}
Сказали написать с использованием процедур, помогите пожалуйста с доработкой программы

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