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

Шаблоны - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Однонаправленный список типа "Очередь". Поменять элементы местами http://www.cyberforum.ru/cpp-beginners/thread878928.html
Всем привет. Есть такая вот задачка: Поменять местами наибольший среди отрицательных и наименьший среди положительных элементов очереди. Как я понимаю,доступ к элементам очереди можно...
C++ Сортировка списка Народ нужна помощь :) Элементы списка представлены следующим образом: class Node { public: char *name; Node *next; Node() { http://www.cyberforum.ru/cpp-beginners/thread878920.html
C++ Месяц и квартал
Задано целое число N (1 ≤ N ≤ 12), которое определят номер месяца в году. По заданному значению N выведите название квартала, к которому принадлежит месяц. Входные данные Единственное число...
Очередь на основе массива C++
Есть код) помогите переделать его под очередь на основе массива =) еще кто знает как перенести функцию вывода print() в дружественную функцию класса так как сказали мне что тип нельзя сделать как...
C++ Операции с динамическим двумерным массивом http://www.cyberforum.ru/cpp-beginners/thread878897.html
Добрый день, мне нужно Сформировать динамический двумерный массив, заполнить его случайными числа-ми и вывести на экран монитора, а затем Добавить строку в начало матрицы. И причем в коде нельзя...
C++ Как добавить элементы в конец, начало, середину list? list<int> m; подробнее

Показать сообщение отдельно
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
26.05.2013, 14:28
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
#include <iostream>
using namespace std;
 
template <class T>
class Vector{
    int size;
    int capacity;
    T* data;
public:
    Vector();
    Vector(int);
    int getSize() const;
    int getCapacity() const;
    T& operator [](int);
    const T& operator [](int) const;
    void push_back(T);
    ~Vector(void);
};
 
template <class  T>
int Vector<T>::getSize() const{
    return this->size;
};
 
template <class  T> 
int Vector<T>::getCapacity() const{
   return this->capacity;
};
 
template <class  T> 
Vector<T>::Vector(int capacity) : size(0), capacity(size),
  data(new T[capacity]) {};
 
template <class  T> 
Vector<T>::Vector() : size(0), capacity(1),
  data(new T[capacity]) {};
 
template <class  T> 
void Vector<T>::push_back(T elem){
    if (size >= capacity) {
        capacity = capacity * 2;
        T* newData = new T[capacity];
        for (int i = 0; i < size; i++)
            newData[i] = data[i];
        delete[] data;
        data = newData;       
    }
    data[size] = elem;
    size++;
};
 
 
template <class  T> 
ostream& operator<<(std::ostream& out, const Vector<T>& diy){
  for (int i = 0; i < diy.getSize(); ++i) {
    out << diy[i];
    if (i < diy.getSize() - 1) {
      out << ",";
    }
  }
  return out;
};
 
 
template <class  T> 
Vector<T>::~Vector(void){
    delete [] data;
};
 
template <class  T>
T& Vector<T>::operator[](int i){
    return data[i];
};
 
template <class  T>
const T& Vector<T>::operator[](int i) const {
    return data[i];
};
 
struct day_in_year{
    int day, month;
    day_in_year(int d, int m):day(d),month(m){}
    day_in_year() : day(1),month(1){}
};
 
std::ostream& operator<<(std::ostream& out, const day_in_year& diy){
    return out << diy.day << "." << diy.month;
}
 
int main(){
    Vector<day_in_year> v;
    cout << v << "\n";
    v.push_back(day_in_year(18, 5));
    v.push_back(day_in_year(23, 6));
    cout << v << "\n";
    cout << v.getSize() << "\n";
    return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru