Форум программистов, компьютерный форум 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()" перепрыгиваю оригинальную подстроку и далее ищу её копию или копии, если такие... подробнее

Показать сообщение отдельно
alsav22
5417 / 4813 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
18.11.2013, 04:33
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
// 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;
        tmp = Start;
        Start = Start->sled;
        delete[] tmp;
        CountQueue--;
        return *this;
    }
};
 
int main(int ArgCount,char**Arguments)
{
    setlocale(0,"");
 
    Queue* Q = new Queue();
 
    *Q + 5;
 
    std::cout<< *Q << std::endl;
 
    --(*Q);
    std::cout<< *Q <<std::endl;
 
    getchar();
    getchar();
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru