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

Класс АТД. Перегрузка операций - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти сумму четных делителей натурального числа http://www.cyberforum.ru/cpp-beginners/thread992125.html
пишу вот так , но не пойму до конца логику расчетов...объясните что забыл? #include <iostream> #include <cmath> #include <windows.h> using namespace std; int main() { setlocale(LC_ALL,"rus");
C++ Сортировка подсчетом нужно решение на С++ Задача: Выходной массив заполняется значениями - 1, затем для каждого элемента определяется его место в выходном массива путем подсчета количества элементов строго меньших данного. Естественно, что все одинаковые элементы попадают на одну позицию, за которой следует ряд значений - 1. После этого оставшиеся в выходном массиве позиции со значением - 1 заполняются копией предыдущего значения. ... http://www.cyberforum.ru/cpp-beginners/thread992120.html
Странная работа прогонки C++
Добрый вечер. Уже целую неделю бьюсь над программой, которая должна решать одномерное уравнение теплопроводности. Задача поставлена так: Ut = Uxx + f(x,t), 0<x<1, 0<t<2 Ux(0,t)=mu1(t), 0<t<2 U(1,t)=mu2(t), 0<t<2 U(x,0)=fi(x), 0<x<1 Я написала программу для решения данной задачи с помощью неявной схемы и схемы Кранка-Николсона (то есть когда параметр "сигма" есть единица или одна вторая...
C++ Даны функции a (x, y, z), b (x, y, z), v (a, b), w (a, b) и f (v, w)
Напишите программу, которая вы- ет значение функции f для нанесенных пользователем x, y, z. Вычисление функций a, b, v и w в программе должно быть задано в виде подпрограмм-функций. Формулы для исчисления ления функций a и b возьмите из таблицы ниже a=(3+exp(y-1))/(1 +(x*x)*abs(y-tan(z)) );4 b=1+abs(y-x)+pow(y-x,2)/2+pow((abs(y-x)),3)/3; v=sqrt(a)+sqrt(b); w=sqrt(a)+b; f=pow((v+w),2)+v*w;...
C++ Написать перегруженную функцию http://www.cyberforum.ru/cpp-beginners/thread992104.html
Написать перегруженные функции и основную программу, которая их вызывает. 1. для сложения целых чисел; 2. для сложения комплексных чисел.
C++ Создание 2d массива определённого размера через функцию обьявляю в классе массив float *arary_2d; пытаюсь создать через void Matrix::set_array(int входяшие данные рамезра) { this->arary_2d = new float ; } так и не получилось реализовать, возможно ли создавать массивы таким образом? Что бы размер можно было указывать самому через функцию? подробнее

Показать сообщение отдельно
egor2116
339 / 370 / 42
Регистрация: 20.01.2013
Сообщений: 1,123
30.10.2013, 12:14     Класс АТД. Перегрузка операций
Как то так наверное на основе массива.

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
#include <iostream>
#include <algorithm>
 
template< class T, unsigned int S >
class Stack
{
private:      
          enum SIZE { MAX=S };
          T * arr;
          T top;
public:
          Stack(){ arr=new T[MAX]; top=0; }
          Stack(const Stack & s)
          {
              arr=new T[s.size()];
               arr=new T[s.size()];
              top=s.getTop();
              for(int i=0; i<MAX; ++i)
                  arr[i]=s.getpArr()[i];
          }
          ~Stack() { delete [] arr; }
          bool isEmpty() { return top==0; }
          bool isFull() { return top==MAX; }
          SIZE size() { return MAX; }
          T * getpArr() { return arr; }
          T   getTop() { return top; }
          void push(const T & elem)
          {
               if(top<MAX) { arr[top++]=elem; }
               else std::cout << "Stack is full"; 
          }
          void input() 
             {
                  T elem;
                  std::cout << "Input element : "; std::cin >> elem;
                  push(elem);
             }
          void output(T & elem) 
             {
                  if(!isEmpty()) { elem=arr[--top]; }
                  else std::cout << "Stack is empty";
             }
          Stack operator=(Stack & s)
          {
              arr=new T[s.size()];
              top=s.getTop();
              for(int i=0; i<MAX; ++i)
                  arr[i]=s.getpArr()[i];
          }
          Stack & operator+(const T & elem)
          {
              push(elem);
          }
          Stack & operator--()
          {
              if(!isEmpty()) --top;
              else std::cout << "Stack is empty"; 
              return *this;
          }
          void print()const
          {
               for(int i=top-1; i>=0; --i)
                  std::cout << arr[i] << std::endl;
          }
          int find(const T & elem)
          {
               for(int i=0; i<MAX; ++i)
                  if(arr[i]==elem) return i;
                  return -1;
          }
};
 
 
int main(){
 Stack<int,5> stack,stack1;
 
 for(int i=0; i<5; ++i)
    stack.input();
    
 stack.print();
 --stack;
 stack.print();
 stack+5;
 stack.print();
 std::cout << "Element 4 finded is position # " << stack.find(4) << std::endl;
 
 
 stack1=stack;
 stack1.print();
 
system("PAUSE");
return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru