Доброго времени суток!
Написал программу, затем узнал, что ее нужно реализовать с помощью класса.
Можно ли это сделать не внося существенных изменений?
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
| #include <stdio.h>
#include <conio.h>
#include <math.h>
#include <stdlib.h>
#include <cstring>
#include <iostream>
#include <windows.h>
using namespace std;
/*Функция поиска элемента массива*/
template <typename T>
void Search(const T data[],int n){
T z;
int g=0;
while(g==0){
cout<<"Введите исскомый элемент: "; cin>> z;
for(int i=0;i<n;i++){
if(data[i] == z){
cout<<"Индекс элемента : "<<i+1<<endl;
g++;
}
}
if (g==0)
cout<<"Вы ввели элемент которого нет в массиве!"<<endl;
}
}
/*Сортировка массива пузырьком*/
template <typename Y>
Y Swap(Y data[],int n){
for (int j=0; j<n; j++)
for (int i=0; i<n-1; i++)
if (abs(data[i])>abs(data[i+1]))
swap(data[i],data[i+1]);
return data[n];
}
int main()
{
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
int *arr; // указатель для выделения памяти под массив
int size; // размер массива
//Ввод количества єлементов массива
cout <<"Введите размерность массива: " ;
cin>>size;
//Проверка размера
if (size <= 0) {
cerr << "Размер масива должен быть положитлеьным!" << endl;
return 1;
}
arr = new int[size]; // выделение памяти под массив
system("CLS");
// заполнение массива
cout <<"Введите элементы массива"<<endl;
for (int i=0; i<size; i++){
cout<< "["<< i+1 <<"]: ";
cin>>arr[i];
}
system("CLS");
Swap(arr,size); //сортировка массива
// Вывод отсортированного массива на экран
cout<<"Упорядоченный массив (по возрастанию): "<<endl;
for (int i=0; i<size; i++)
cout << arr[i]<<' ';
cout<<endl;
Search(arr,size); //поиск элемента
delete [] arr; // освобождение памяти
return 0;
} |
|
Добавлено через 1 час 6 минут
Написал.
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
| #include <stdio.h>
#include <conio.h>
#include <math.h>
#include <stdlib.h>
#include <cstring>
#include <iostream>
#include <windows.h>
using namespace std;
template <typename T>
class MyClass
{
private:
int *arr; // указатель для выделения памяти под массив
int size; // размер массива
public:
/** Конструктор **/
MyClass()
{
InArray();
}
/** Деструктор **/
~MyClass()
{
}
/** Ввод массива **/
InArray()
{
//Ввод количества єлементов массива
cout <<"Введите размерность массива: " ;
cin>>size;
//Проверка размера
if (size <= 0) {
cerr << "Размер масива должен быть положитлеьным!" << endl;
return 1;
}
arr = new int[size]; // выделение памяти под массив
system("CLS");
// заполнение массива
cout <<"Введите элементы массива"<<endl;
for (int i=0; i<size; i++){
cout<< "["<< i+1 <<"]: ";
cin>>arr[i];
}
system("CLS");
}
/** Сортировка массива пузырьком **/
T Swap(){
for (int j=0; j<size; j++)
for (int i=0; i<size-1; i++)
if (abs(arr[i])>abs(arr[i+1]))
swap(arr[i],arr[i+1]);
OutArray();
return arr[size];
}
/** Функция поиска элемента массива **/
void Search(){
T z;
int g=0;
while(g==0){
cout<<"Введите исскомый элемент: "; cin>> z;
for(int i=0;i<size;i++){
if(arr[i] == z){
cout<<"Индекс элемента : "<<i+1<<endl;
g++;
}
}
if (g==0)
cout<<"Вы ввели элемент которого нет в массиве!"<<endl;
}
delete [] arr; // освобождение памяти
}
/** Вывод массива**/
void OutArray(){
cout<<"Упорядоченный массив (по возрастанию): "<<endl;
for (int i=0; i<size; i++)
cout << arr[i]<<' ';
cout<<endl;
}
};
int main()
{
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
lone:
string type;
system("cls");
cout<< "С каким типом данных работать? ";
cin>> type;
system("cls");
if (type=="int")
{
MyClass<int> MyObject;
MyObject.Swap();
MyObject.Search();
} else
{
if (type== "float" )
{
MyClass<float> MyObject;
MyObject.Swap();
MyObject.Search();
} else
{
if (type=="double")
{
MyClass<double> MyObject;
MyObject.Swap();
MyObject.Search();
}else
{
if(type=="char"){
MyClass<char> MyObject;
MyObject.Swap();
MyObject.Search();;
}else
{
system("cls");
cout<< "Вы можете работать только с int, float, double, char, попробуйте еще раз!" <<endl;
system("pause");
goto lone;
}
}
}
}
return 0;
} |
|