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

Сделать массив расширяемым - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с сайтами http://www.cyberforum.ru/cpp-beginners/thread1492650.html
Где найти информацию о том как взаимодействовать с сайтами(например вставить в поле логин - логин и т.д.).Работаю на Visual c++,MFC.Об CGI тоже пока не нашел понятной статьи.
C++ Задача на Базу данных о продаже автомобилей Помогите написать программу на поставленную задачу. Как мне сказали: программа должна получиться где-то 30-59 строчек кода. Вот само задание: Дан файл записей о продаже авто по след. структуре:... http://www.cyberforum.ru/cpp-beginners/thread1492649.html
Вызов оконной функции в диалоговом окне C++
есть Добавлено через 7 минут есть программа с диалоговым окном и программа с оконной функцией, надо чтобы при нажатии кнопки в диалоговом окне выполнялась программа с оконной функцией, разное...
C++ Рекурсивная функция выводящая содержимое вектора
Никаких идей как это сделать. В книге всего пол страницы посвящены этой теме.
C++ Разработка программы с использованием подпрограммы http://www.cyberforum.ru/cpp-beginners/thread1492598.html
В матрице A( n- строк, m- столбцов; n- четное) поменять местами наибольшие элементы в ее верхней и нижней половинах. Для поиска индексов наибольшего элемента в заданной части матрицы использовать...
C++ Вывод списка #include <stdio.h> #include <conio.h> #include <vld.h> #include <locale.h> #include <Windows.h> #define size 20 using namespace std; struct List подробнее

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

Сделать массив расширяемым - C++

03.07.2015, 23:18. Просмотров 242. Ответов 7
Метки (Все метки)

Никак не получается сделать динамический массив расширяемым , помогите пожалуйста, где,что не так?
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
#include<iostream>
using namespace std;
 
class myVector
{
 int *arr, size,var,count;
public:
    myVector(int s=5):var(0), size(s), count(0)
    {
        arr=new int[size];
        
        }
    ~myVector()
    {
        if (arr) delete[]arr;
    }
    void addEnd(int x);
    void addFirst(int x);
    void addIndex(int x, int pos);
    void show();
};
void myVector::addEnd(int x)
{
 
    if (count>=size)
    {
        int *temp=new int[size];
        for(int i=0;i<=count;i++)
            temp[i]=arr[i];
        delete []arr;
        size=2*size;
        arr=new int[size];
        for (int i=0;i<=count;i++)
            arr[i]=temp[i];
        arr[count+1]=x;
        count ++;
        delete []temp;
}
    else 
    {
        arr[count+1]=x;
count ++;
    }
}
void myVector::addFirst(int x)
{
    if (count<size)
    {
        int *temp=new int[size];
        temp[0]=x;
        for (int i=0;i<=count;i++)
            temp[i+1]=arr[i];
        
        for (int i=0;i<=count+1;i++)
            arr[i]=temp[i];
        count++;
        delete []temp;
    }
    else
    {
        size=size*2;
        int *temp=new int[size];
        temp[0]=x;
        for(int i=0;i<=count;i++)
        temp[i+1]=arr[i];
        delete []arr;
        arr=new int[size];
        for(int i=0;i<=count+1;i++)
            arr[i]=temp[i];
        count++;
        delete []temp;
 
 
    }
}
void myVector::addIndex(int x, int pos)
{
    if (count<size)
    {
        int *temp=new int[size];
        for (int i=0;i<pos;i++)
            temp[i]=arr[i];
        
        for(int i=pos;i<=count;i++)
            temp[i+1]=arr[i];
        temp[pos]=x;
        for (int i=0;i<=count+1;i++)
            arr[i]=temp[i];
        count++;
        delete []temp;
        }
    else
    {
        size=2*size;
        int *temp=new int[size];
        temp [pos]=x;
        for (int i=0;i<pos;i++)
            temp[i]=arr[i];
        for(int i=pos;i<=count;i++)
            temp[i+1]=arr[i];
        delete []arr;
        arr=new int[size];
        for (int i=0;i<=count+1;i++)
            arr[i]=temp[i];
        count++;
        delete []temp;
 
    }
}
void myVector::show()
{
    for(int i=1; i<=count;i++)
    {
        cout<<arr[i]<<" ";
 
    }
    cout<<endl;
}
 
int main()
{
    setlocale( LC_ALL,"Russian" );
    myVector arr;
    int pos, c,x;
    
    while(true)
    {
    cout<<"выберите действие"<<endl<<"1.добавить элемент в конец"<<endl<<"2.добавить элемент в начало"<<endl<<"3.добавить элемент в середину с указанием индекса"<<endl;
    cout<<"0.вывести на экран"<<endl;
    cin>>c;
    switch(c)
    {
    case 1:
        {
            cout<<"введите добавляемый элемент"<<endl;
                cin>>x;
            arr.addEnd(x);
            break;
        }
    case 2:
        {
            cout<<"введите добавляемый элемент"<<endl;
            cin>>x;
            arr.addFirst(x);
            break;
        }
    case 3:
        {
            cout<<"укажите позицию добавляемого элемента"<<endl;
            cin>>pos;
            cout<<"введите добавляемый элемент"<<endl;
            cin>>x;
            arr.addIndex(x,pos);
            break;
        }
    case 0:
        {
            arr.show();
            break;
        }
    default:
        exit(1);
    }
    }
 
 
system("pause");
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru