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

нужно разобраться с кодом - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Подскажите пожалуйста, фантазии уже не хватает. http://www.cyberforum.ru/cpp-beginners/thread418369.html
Как осуществить поиск максимального и минемального числа в одномерном массиве с помощью рекурсии, тремя разными способами пробова: 1.По отдельности их написать. 2.Смешать вмести. 3.Две функции ввести. Все неправильно работают, в форе это пару минут, а вот с рекурсией у меня как то не заладилось((( Уже столько времени сижу.
C++ Шаблон класса списка Здравствуйте! У меня шаблон класса Список template <typename T> class List { private: struct Node { T Data; Node *Prev, *Next; http://www.cyberforum.ru/cpp-beginners/thread418363.html
C++ Задача на массив
Добрый вечер. В программировании я недавно - так что у меня есть проблемы даже с элементарными вещами. Столкнулся с такой задачей : При выполнении работы используются статические массивы. Для организации статических массивов с псевдопеременными границами необходимо объявить массив достаточно большой длины N. Затем пользователь вводит реальную длину массива (не больше N) и работает с массивом...
C++ Не могу создать файлы входных и выходных данных
Не понимаю что неправильно в открытии и создании input.txt и output.txt В универе на линуксе не надо писать путь а просто FILE *in; in=fopen("input.txt","r"); Пробую дома в Dev-c, но ни просто имя файла ни с указанием пути с двойными \\ файлы не создаются. Вручную создавал, данные не считываются и не записываются. #include <stdio.h> #include <stdlib.h>
C++ структуры данных.списки http://www.cyberforum.ru/cpp-beginners/thread418338.html
пытаюсь вывести из файла на консоль каталог,содержащий имя файла,дату создания,количество обращений к файлу. не подумайте,что совсем идиот и для чтения из файла использую структуры данных,ибо это лишь часть лабы,просто пытаюсь по частям делать её. в общем,проблема в том,что компилятор выдаёт какую-то непонятную для меня ошибку,а попытка ребилд солюшн почему-то глючит систему и приводит к...
C++ нужно подправить нужно изменить этот код так ,что бы программа смогла "выжить" в разных ситуациях 1 если знаменатель = 0 и не могу никак понять что обозначает 2корень из -х 3 tg 4 ln и без использования объектно ориентированных средств ввода вывода ,т.е. принф. #define _USE_MATH_DEFINES #include<iostream> подробнее

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

нужно разобраться с кодом - C++

26.12.2011, 22:19. Просмотров 232. Ответов 0
Метки (Все метки)

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
#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;
}
он рабочий 100%
вот только проблемма понять что он делает за чем..нужна помощь в понятии и осознании того что здесь выполняется вот само задание:
Осуществить циклический сдвиг элементов прямоугольной матрицы на n элементов вправо или вниз (в зависимости от введенного режима). n может быть больше количества элементов в строке или столбце.
я нашол этот код на этом сайте и задание тоже вот просто для себя хочу разобраться что здесь происходит..в общем я понимаю а чтгобы отдельные строчки обьяснить не могу((
буду очень благодарен за помощь
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru