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

Доработать код для магического квадрата - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ массивы http://www.cyberforum.ru/cpp-beginners/thread222434.html
Заполните массив целого типа значениями, образованными из степеней двойки: в mas записывается 2 в степени 0, в mas записывается 2 в степени 1, в mas записывается 2 в степени 2 и т.д., после чего выведите данные массива на экран.использовать библиотеку только #include <stdio.h> и через printf и scanf
C++ Точка в треугольнике Помогите! даны три вершины треугольника с координатами(коорд вводятся с клавиатуры) А(х1,y1) B(х2,y2) и С(х3,y3). И вводятся координаты другой точки Д(х4,y4)-и нужно определить принадлежит эта точка треугольнику или нет!А перед этим еще проверить возможен ли треугольник с такими точками. http://www.cyberforum.ru/cpp-beginners/thread222429.html
C++ Внешний файл
есть программа нужно, чтобы она брала данные через внешний файл #include "stdafx.h" #include <conio.h> #include <stdio.h> #include <iostream> #include <math.h> #define size 15 using namespace std; void _tmain()
C++ Сортировка
Нужна помощь с этой задачей: Дано произвольное целое положительное число K (K<10^9). Вывести цифры этого числа в порядке неубывания (например, 546085 =>045568). Процедуры и функции работы со строками не использовать.
C++ Константные статические объекты класса. http://www.cyberforum.ru/cpp-beginners/thread222394.html
Здравствуйте. Есть класс "матрица" нужно задать константные матрицы такие как E - единичная матрица и т.д., как это сделать? #include <iostream> #include <sstream> #include <string> #include <vector> #include <map> #include <set> #include <algorithm> #include <limits> #include <iomanip>
C++ Как массив разнозначных чисел превратить в массив цифр? (С++) (Я делаю на Builder 6, С++ на консоли) У меня в курсаче есть такое задание: Для введённого целого числа N определить N-ую ЦИФРУ последовательности. Последовательность составляется так: Это ЧИСЛА Фибоначчи, Последующее = сумме двух предыдущих (F = F + F) Даны F = 0, F = 1. Т.е. дальше будет так: F = F + F = 1, F=1+1=2, F=2+1=3 и т.д. будут такие ЧИСЛА:... подробнее

Показать сообщение отдельно
sandye51
программист С++
 Аватар для sandye51
677 / 579 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
29.12.2010, 19:25     Доработать код для магического квадрата
Цитата Сообщение от GoreOtUma Посмотреть сообщение
двух главных диагоналей
бывает только одна главная)
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
#include <iostream>
#include <algorithm>
#include <conio.h>
#include <stdio.h>
#include <numeric>
 
using namespace std;
 
void Fail(void)
{
        cout << "Введенная матрица не является магическим квадратом" << endl;
        _getch();
        exit(EXIT_FAILURE);
}
 
int main()
{
        setlocale(LC_ALL, "Russian");
        size_t m;
 
        cout << "Введите порядок матрицы " << endl;
        cin >> m;
 
        int **matrix = (int**) realloc(NULL, sizeof(int*) * m);
        for (size_t i = 0; i < m; ++i)
                matrix[i] = (int*) realloc(NULL, sizeof(int) * m);
 
        // вводим матрицу;
        cout << "Введите элементы матрицы последовательно " << endl;
        for (size_t i = 0; i < m; ++i)
                for(int j = 0; j < m; ++j)
                        cin >> matrix[i][j];
 
        int PartSum = accumulate(matrix[0], matrix[0] + m, 0);
        // проверяем является ли матрицы магическим квадратом;
        // 1. равенство по строкам;
        for(size_t i = 1; i < m; ++i)
                if (PartSum != accumulate(matrix[i], matrix[i] + m, 0))
                        Fail();
 
        // 2. Равенство по стобцам;
        for(size_t i = 1; i < m; ++i)
                if (PartSum != accumulate(*(matrix + i),*(matrix + i) + m, 0))
                        Fail();
 
        // 3. Проверка по диагонали;
        int Sum1 = 0, Sum2  = 0;
        for (size_t i = 0; i < m; ++i)
                Sum1 += matrix[i][i], Sum2 += matrix[i][m - i - 1];
        if (PartSum != Sum1 || PartSum != Sum2)
                Fail();
 
        cout << "Введенная матрицы является магическим квадратом" << endl;
        _getch();
        for (size_t i = 0; i < m; ++i)
                matrix[i] = (int*) realloc(matrix[i], NULL);
        matrix = (int**) realloc(matrix, NULL);
 
        return 0;
}
 
Текущее время: 01:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru