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

разобраться с очередью - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Наследование и связный список http://www.cyberforum.ru/cpp-beginners/thread1010367.html
Пытаюсь сделать связный список, используя наследование при этом. Есть класс Person - имя, и указатель на следующий элемент, операция копирования(чтобы не юзабельна была) и функция добавления в список - все под private, дабы не использовалось во вред. Под public - статическая переменная под голову списка(list_begin), конструктор, вирт деструктор, виртуальная функция и вспомогательные. Далее 3...
C++ Не могу найти ошибку в массиве Добрый вечер. Никак не могу найти ошибку. Спасибо за помощь # include <iostream> # include <math.h> # include <conio.h> # include <stdio.h> using namespace std; int main() { setlocale(LC_ALL,"RUS"); http://www.cyberforum.ru/cpp-beginners/thread1010365.html
C++ Строки и работа с файлами
Дан текст в файле input.txt. Проверяет чтобы после каждой точки предложение начиналось с большой буквы.Корректный текст записывает в файл output.txt.Корректно преобразует только первую строку.Но если в файле input.txt написать слово или предложение с новой строки,происходит ошибка .Задача состоит в том,чтобы происходило считывание из файла с новой строки.Помогите,пожалуйста! #...
C++ Одинаковые цифры в числах
Введите два числа А и В. Проверьте, есть ли у них одинаковые цифры. Даже не понимаю, с какой стороны подходить к программе.
C++ Матрицы на с++ http://www.cyberforum.ru/cpp-beginners/thread1010342.html
В университете задали задачу: Заменить знак на противоположный в элементах матрицы, A=(a), i=j=1,2,...m, которые размещены в рядках и начинаются с отрицательных элементов. Посчитать питомый вес элементов, которые менялись. Возникли следующие вопросы: -Как реализовать изменение знака на противоположный? -И что такое питомый вес элементов? Буду очень благодарен за подсказки!
C++ Удаление одинаковы строк Допустим у меня есть строка s и я хочу удалить одинаковые подстроки в ней. Сначала я извлекаю подстроки до символа '\n' из s с помощью функции read_line. При первом вызове этой функции я получу subs = "Hello world\n" ну и т. д. В цикле while сначала игнорирую оригинальную подстроку. С помощью "it + subs.size()" перепрыгиваю оригинальную подстроку и далее ищу её копию или копии, если такие... подробнее

Показать сообщение отдельно
proech
10 / 10 / 2
Регистрация: 10.07.2013
Сообщений: 150
17.11.2013, 20:48     разобраться с очередью
не работает operator+ и оператор--
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
// ConsoleApplication85.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <cstdio>
#include <iostream>
#include <conio.h>
#include <locale>
 
typedef struct listItem
{   
    int Data;
    listItem* sled;
}
QueueElement;
class Queue
{
private:
    QueueElement* Start;
    QueueElement* End;
    unsigned int CountQueue;
    void AddTolist(QueueElement *&Start,QueueElement *&End,QueueElement *Temp)
    {
    
        if (Start)
        {
        End->sled = Temp;
        End = Temp;
        }
        else 
        {
          Start = End = Temp;
        };
    
    }
public:
//по Умолчанию
    friend std::ostream &operator<<(std::ostream &Stream,const Queue &q)
    {
        QueueElement *tmp= q.Start;
        while(tmp)
        {
        
        Stream<<tmp->Data<<" "<<std::endl;
        
        tmp = tmp->sled;
        }
        return Stream;
    }
    Queue():CountQueue(5)
    {
        std::cout<<"количество элементов"<<std::endl;
        std::cin>>CountQueue;
     Start = End = NULL;
     QueueElement* temp;
 
     
    for (int i=0;i<CountQueue;i++)
    {
     temp = new QueueElement;
    std::cin>>temp->Data;
    temp->sled = NULL;
    AddTolist(Start,End,temp);
    }
 
    
    }
    ~Queue()
    {QueueElement *tmp = this->Start;
        while(Start)
        { tmp = Start;
        Start = Start->sled;
        delete tmp;
         
        }
    
    }
    Queue &operator+(int Number)
    { 
        std::cout<<" добавили элемент "<<Number<<std::endl;
    QueueElement* tmp =new QueueElement;
    tmp->Data = Number;
    tmp->sled = NULL;
    AddTolist(Start,End,tmp);
    CountQueue++;
    return *this;
    }
    unsigned int Lenght()
    {
    return CountQueue;
    }
    bool empty() const{return Start ==NULL;}
    
    Queue &operator--()
    {
        std::cout<<"извлекли элемент  : "<<Start->Data<<std::endl;
    QueueElement*tmp = new QueueElement;
    tmp = Start;
    Start = Start->sled;
   delete[] tmp;
    CountQueue--;
    }
};
    int main(int ArgCount,char**Arguments)
    {setlocale(2,"rus");
 
    Queue* Q = new Queue();
 
    Q+5;
 
    std::cout<<Q<<std::endl;
 
    Q--;
    std::cout<<Q<<std::endl;
 
    getchar();
    getchar();
    return 0;
    }
Миниатюры
разобраться с очередью  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru