Форум программистов, компьютерный форум 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 и т.д. будут такие ЧИСЛА:... подробнее

Показать сообщение отдельно
Минич
66 / 66 / 3
Регистрация: 26.11.2010
Сообщений: 123
30.12.2010, 02:24
Магический квадрат: http://ru.wikipedia.org/wiki/%D0%9C%...80%D0%B0%D1%82
Вот моя версия:
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
87
88
89
90
91
92
93
94
95
96
97
98
#include <fstream>
#include <iostream>
#include <string>
#include <math.h>
#include <iomanip>
using namespace std;
void main()
{
    setlocale(LC_ALL, "Russian");
    ifstream infile("test.txt");
    int n = 0;
    string tempStr;
    // определение количество элементов массива
    while (!infile.eof()) {
        infile >> tempStr;
        n++;
    }
    n = static_cast<int>(sqrt(static_cast<double>(n)));
    infile.close();
 
    // выделение памяти под двумерный динамический массив
    int **pArr = new int*[n];
    for (int i = 0; i < n; i++) {
        pArr[i] = new int[n];
    }
    // заполнение массива из файла
    int i = 0;  
    ifstream file("test.txt");
    while (!file.eof()) {
        file >> pArr[i/n][i%n];
        i++;
    }
    file.close();
 
    // проверка на единственность значения в массиве
    for (int i = 0; i < n*n; i++)
        for (int j = i + 1; j < n*n; j++)
            if (pArr[i/n][i%n] == pArr[j/n][j%n]) {
                cout << "Не магический квадрат!" << endl;
                cin.get();
                return;
            }
    int sum = 0;
    for (int i = 0; i < n; i++) sum += pArr[i][0];
    int tempSum;
    // проверка строк
    for (int i = 0; i < n; i++) {
        tempSum = 0;
        for (int j = 0; j < n; j++)
            tempSum += pArr[i][j];
        if (tempSum != sum) {
            cout << "Не магический квадрат!" << endl;
            cin.get();
            return;
        }
    }
    // проверка столбцов
    for (int i = 0; i < n; i++) {
        tempSum = 0;
        for (int j = 0; j < n; j++)
            tempSum += pArr[j][i];
        if (tempSum != sum) {
            cout << "Не магический квадрат!" << endl;
            cin.get();
            return;
        }
    }
    // проверка диагоналей
    tempSum = 0;
    for (int i = 0; i < n; i++)
        tempSum += pArr[i][i];
    if (tempSum != sum) {
        cout << "Не магический квадрат!" << endl;
        cin.get();
        return;
    }
    tempSum = 0;
    for (int i = 0; i < n; i++)
        tempSum += pArr[i][n-i-1];
    if (tempSum != sum) {
        cout << "Не магический квадрат!" << endl;
        cin.get();
        return;
    }
 
    // вывод массива на экран   
    cout << "Матрица является магическим квадратом:" << endl;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++)
            cout << setw(5) << pArr[i][j];
        cout << endl;
    }
        
    for (int i = 0; i < n; i++)
        delete[] pArr[i];
    delete[] pArr;  
    cin.get();
}
test.txt содержит:
C++
1
2
3
4
7 12 1 14
2 13 8 11
16 3 10 5
9 6 15 4
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru