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

нужно обьяснить что происходит в программе - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Массивы структур, столкнулся с небольшой проблемой! http://www.cyberforum.ru/cpp-beginners/thread419601.html
Всем доброго дня, столкнулся с небольшой проблемой, вот собственно само задание и код: Написать консольную программу на языке C++ с использованием структур. Программа должна позволять пользователю добавлять данные в массив структур, просматривать этот массив, а также выполнять дополнительную операцию в соответствии с индивидуальным заданием. Поля структуры: код предприятия, название, сумма...
C++ Написать функцию, обеспечивающую решение квадратного уравнения Написать функцию, обеспечивающую решение квадратного уравнения. Параметрами функции должны быть коэффициенты и корни уравнения. Значение, возвращаемое функцией, должно передавать в вызывающую программу информацию о наличии уравнения корней: 2 - два разных корня, 1 - корни одинаковые, 0 - уравнение не имеет решения. Кроме того функция должна проверять корректность исходных данных. Если исходных... http://www.cyberforum.ru/cpp-beginners/thread419600.html
C++ Заполнить случайными числами матрицу А(mxn) и В(mxn) и вывести их на экран в виде таблицы
Заполнить случайными числами матрицу А(mxn) и В(mxn) и вывести их на экран в виде таблицы, окрасив элементы главных диагонали красным цветом. Программа определяет, сколько нулей в матрице С=А+В и результат выводит на экран вместе с матрицей С. Добавлено через 56 минут девушке нужна ваша помощь. я уверена тут много умных людей : )
Переставить местами первую и последнюю цифры C++
Дано четырехзначное натуральное число.Переставить местами первую и последнюю цифры
C++ Напечатать предложение после удаления средней буквы для слов неточной длины http://www.cyberforum.ru/cpp-beginners/thread419590.html
Напечатать предложение после удаления средней буквы для слов неточной длины Помагите буду очень признательна =) Именуйте темы осмысленно! Один вопрос - одна тема!
C++ Разработать класс для представления вещественный чисел... Разработать класс для представления вещественных чисел, задаваемыъ тройкой целых чисел (целая часть числа, дробная часть числа, кол-во цифр в дробной части). Максимальное число цифр в дробной части - 5. Пример: 12.00341 = (12,341,5) Класс должен включать весь необходимый интерфейс: конструкторы, перегрузку операций (в том числе +=, +, ++, -=, -, =, <, <=, ==), другие необходимые методы. На... подробнее

Показать сообщение отдельно
anton6262906
0 / 0 / 0
Регистрация: 13.10.2011
Сообщений: 17
28.12.2011, 12:06     нужно обьяснить что происходит в программе
Осуществить циклический сдвиг элементов прямоугольной матрицы на n элементов вправо или вниз (в зависимости от введенного режима). n может быть больше количества элементов в строке или столбце.
код я нашол надо только обьяснить в коментариях типа "//" что выполняется в программе,что мы обьявляем,что делает эта строчка ну вот такого типа нужно сделать это ато не допустят до сессии я думаю разберусь с программой сам если поможете написать комментарии
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
[QUOTE][CODE]
#include <iostream>//подключение библиотек
 
using namespace std;
typedef int* stroka;              
 
class Matrix
{
public:
        stroka* matrix;
        int a, b;//обьявление переменных
        Matrix(int a1, int b1)
        {
                this->a = a1, this->b = b1;
                matrix = new stroka[a];
                for (int i = 0; i < a; ++i)
                        matrix[i] = new int[b];
        }
        ~Matrix(void)
        {
                for (int i = 1; i < a; ++i)
                        delete[]matrix[i];
                delete[]matrix;
        }
        void sdvig (int flag, int sdvig, int index)
        {
                if (!(sdvig % a) && flag == 2 || flag == 1 && !(sdvig % b))
                        return;
                else
                        if (flag == 2 && index >= 0 && index < b) // столбец
                        {
                                sdvig = sdvig > 0 ? sdvig % a : sdvig % a + a;
                                int* tmp = new int[sdvig];
                                for (int i = 0; i < sdvig; ++i)
                                {
                                        tmp[i] = matrix[a - sdvig + i][index];                                           // сохраняем последние элементы [сдвиг]
                                        matrix[a - sdvig + i][index] = matrix[(a - 2*sdvig + i >= 0 ? a - 2*sdvig + i : (2 * (a - sdvig) + i) % a)][index];     // на их место предыдущие [сдвиг]
                                }
                                for ( i = a - sdvig; i >= sdvig; --i)
                                        matrix[i][index] = matrix[i - sdvig][index];
                                for ( i = 0; i < sdvig; ++i)
                                        matrix[i][index] = tmp[i];
                                delete[]tmp;
                        }
                        else 
                                if (flag == 1 && index >= 0 && index <= a) // строка
                                {
                                        sdvig = sdvig > 0 ? sdvig % b : sdvig % b + b;
                                        int* tmp = new int[sdvig];
                                        for (int i = 0; i < sdvig; ++i)
                                        {
                                                tmp[i] = matrix[index][b - sdvig + i];                                           // сохраняем последние элементы [сдвиг]
                                                int t = b - 2*sdvig + i >= 0 ? b - 2*sdvig + i : (2 * (b - sdvig) + i) % b;
                                                matrix[index][b - sdvig + i] = matrix[index][t];        // на их место предыдущие [сдвиг]
                                        }
                                        for ( i = b - sdvig; i >= sdvig; --i)
                                                matrix[index][i] = matrix[index][i - sdvig];
                                        for ( i = 0; i < sdvig; ++i)
                                                matrix[index][i] = tmp[i];
                                        delete[]tmp;
                                }
        }
        friend ostream& operator<< (ostream& os, const Matrix& Buffer)
        {
                for (int i = 0; i < Buffer.a; ++i)
                {
                        for (int j = 0; j < Buffer.b; ++j)
                                os << Buffer.matrix[i][j] << "  ";
                        os << endl;
                }
                return os;
        }
};
 
int main(void)
{
        Matrix Buffer(7, 5);
 
        for (int i = 0; i < Buffer.a; ++i)
                for (int j = 0; j < Buffer.b; ++j)
                        Buffer.matrix[i][j] = i + j + 1;        
        
        
        cout << Buffer << endl;
        Buffer.sdvig(1 /* столбец */, 3 /* сдвиг*/ , 3);
        cout << Buffer;
 
        system("Pause");
        return 0;
}[/CODE][/QUOTE]
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru