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

перегрузка инкремента в постфиксной форме для двумерного массива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ конвертация hex to base64 http://www.cyberforum.ru/cpp-beginners/thread875587.html
Есть консольное приложение, при помощи функции получаю hex под типом char*, вот теперь надо это перевести в base64, я по нету полазал, чото нашёл, но там какято либа левая юзается, подскажите или покажите как это можно сделать (нехотелось бы велосипед изобретать)
C++ нужен совет!Что где и для чего) #include <iostream.h> #include <conio.h> #include <math.h> using namespace std; #define gcd 0x000A #define inv 0x000B // first > second // inv - инверсия http://www.cyberforum.ru/cpp-beginners/thread875575.html
Параллельное программирование C++
Кто-нибудь использовал в своей жизни? Если да, то какой? И были ли положительные результаты в плане ускорения? О, да... Может, кто CUDA использовал? Или AMD Stream?
C++ Создания цикла for внутри логических функций
Уважаемые форумчане, возможно ли на языке С++ создавать циклы внутри логических функций? В данной программе ввод нечетного числа в промежутке от 6 до 40 является неверным диаметром арматуры. #include <iostream> using namespace std; int main() { cout << "Vvedite diametr armaturi: "; int d; //диаметр арматуры
C++ Указатели или ссылки (в качестве аргументов функции) ? http://www.cyberforum.ru/cpp-beginners/thread875504.html
В каких случая надо использовать ссылки и в каких указатели в качестве аргументов функции? В общем поняла, что и те и другие полезны для ссылания на крупные обьекты типа классов. :scratch:
C++ как написать так что бы ,она выдавала хотите ли вы продолжить ввод #include <iostream> #include <ctime> #include <iomanip> using namespace std; void out(double *a,int n); void out(double *a,int n,int k); void vin(double *a,int n); void mult(double *a,double *x,int n); void oper(double *a,double *b,double *x,double *y,int n); подробнее

Показать сообщение отдельно
Headmaster
0 / 0 / 0
Регистрация: 08.05.2013
Сообщений: 75
23.05.2013, 12:08     перегрузка инкремента в постфиксной форме для двумерного массива
Для одномерного массива в префиксной и постфиксной форме получилось сделать. Для двумерного только в префиксной.

Пример для одномерного
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
#include <iostream>
#include <string>
#include <iostream>
#include <string>
#include <math.h>
#include <time.h>
#include <stdlib.h>
using namespace std;
 
class Array
{
    int size;
    int *arr;
public:
    Array();
    Array(int =0);
    Array(const Array &ob);
    ~Array();
    void show();
    int sum();
    Array &operator ++();
    Array operator ++(int);
};
Array &Array::operator ++()
{
    for(int i = 0; i < this->size; i++)
        this->arr[i]++;
    return *this;
}
Array Array::operator ++(int)
{
    Array buf(*this);
    for (int i = 0; i < this->size; i++)
        this->arr[i]++;
    return buf;
}
Array::Array(const Array &ob):size(ob.size)
{
    arr=new int [size];
    for(int i=0;i<size;i++)
        arr[i]=ob.arr[i]; 
}
Array::Array(int N)
{
    size=N;
    arr=new int [size];
    for(int i=0;i<size;i++)
        arr[i]=rand()%10;
}
Array::~Array()
{
    delete [] arr;
}
void Array::show()
{
    int sum=0;
    for(int i=0;i<size;i++)
    {
        sum+=arr[i];
        cout<<"["<<i<<"]="<<arr[i]<<endl;
    }
        cout<<sum<<endl;
}
int Array::sum()
{
    int sum=0;
    for(int i=0;i<size;i++)
        sum+=arr[i];
    return sum;
}
void main()
{
    Array A(10);
    Array B(15);
    if(A.sum() < B.sum())
    {
        cout<<"B"<<endl;
    }
    else
    {
        cout<<"A"<<endl;
    }
    A.show();
    A++;
    A.show();
    ++A;
    A.show();
}
Проблемы возникают с двумерным (префиксная работает, постфиксная - нет)
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>
#include <string>
#include <math.h>
#include <time.h>
#include <stdlib.h>
using namespace std;
 
class Array
{
    int **mass;
    int row, col;
public:
    Array(int =0,int =0);
    ~Array();
    int max();
    void print(void);
    Array &operator ++();
    Array operator ++(int);
};
Array &Array::operator ++()
{
    for (int i = 0; i < this->row; i++)
    {
        for(int j = 0; j < col; j++)
            this->mass[i][j]++;
    }
    return *this;
}
Array Array::operator ++(int)
{
    Array buf(*this);
    for (int i = 0; i < this->row; i++)
    {
        for(int j = 0; j < col; j++)
            this->mass[i][j]++;
    }
    return buf;
}
Array::Array(int n,int m)
{
    row=n;
    col=m;
    if (row<0 || col<0)
    {
        cout<<"Size"<<endl; 
        exit(1);
    }
    mass=new int*[row];
    cout << "Vvedite zadanii massiv:" << endl;
    for(int i=0;i<row;i++)
    {
        mass[i]=new int[col];
        for(int j=0;j<col;j++)
            cin >> mass[i][j];
    }
}
Array::~Array()
{
    for (int i=0; i<row; i++)
        delete []mass[i];
    delete []mass;
}
int Array::max()
{
    int max = mass[0][0];
    for(int i = 0; i < row; i++)
    {
        for(int j = 0; j < col; j++)
        {
            if(max < mass[i][j])
            {
                max = mass[i][j]; 
            }
        }
    }
    return max;
}
void Array::print(void)
{
    cout << "Max element " << max() << endl;
}
void main()
{   
    Array K(2, 3);
    K.print();
    cout << K(1,2) << endl;
    K++;
    K.print();
}
Надеюсь я ничего лишнего из кода не выкинул)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru