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

Ошибка в работе с классом "очередь" - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дать совет по ООП http://www.cyberforum.ru/cpp-beginners/thread53334.html
Скажите, на какой вид проектов на студии 2005 стоит переходить после изучения полностью консоли на с++ в студии 2005, чтоб писать полноценные приложения виндоус на форме с использованием кнопок и т.д.
C++ Работа с графикой Доброго времени суток ув. форумчане. Вобщем так, я еще совсем новичок, пытаюсь написать программу, задача ее в том чтобы выводить на экран текст нужного цвета. Работаю в Dev C++. Сначала проблема была в том что там отсутствовала графическая библиотека graphics.h, я ее нашел и установил. А теперь я не могу понять как заставить программу вывести текст и придать ему цвет, так как рисовать... http://www.cyberforum.ru/cpp-beginners/thread53332.html
C++ Нужен коментарий
Народ прокоментируйте этот код: #pragma once template <class T> struct TreeEl{ T data; TreeEl<T> *pLeft,*pRight,*pParent; TreeEl(T d):data(d),pLeft(0),pRight(0),pParent(0) {}
Массив на 200 элементов C++
Задача в С . дан массив размером 200, заполнить его случайными числами в интервале от -50 до 50 . Далее определить какое значение встречается в массиве чаще остальных и вывести на экран какое это значение и сколько раз оно встречается ?
C++ вывод пикселя http://www.cyberforum.ru/cpp-beginners/thread53272.html
Привет всем. Мне нужна ваша помощь. Вообщем задание таково: Построить программу, которая вводит координаты точки (x, y) и определяет, попадает ли точка в заштрихованную область на рисунке, который соответствует Вашему варианту(рисунок прикреплен ). Попадание на границу области считать попаданием в область. Вообщем я написал прогу все работает кроме: я ввожу координаты пикселя, пиксел...
C++ задача на определения элементов в строке Дана строка. Подсчитать количество содержащихся в ней прописных латинских букв. Помогите плз. Задачу надо сначала без использования массивов, а потом с использования массивов. :wall: :help: подробнее

Показать сообщение отдельно
FW-TOT
1 / 1 / 0
Регистрация: 04.03.2009
Сообщений: 17

Ошибка в работе с классом "очередь" - C++

30.09.2009, 15:43. Просмотров 471. Ответов 4
Метки (Все метки)

Скажите пожалуйста, почему указатель на хвост очереди после инициализации всегда направлен в NULL, а на голову в адрес 158? (через конструктор программа проходит нормально)
Почему функция заполнения не вносит никаких изменений, видимых при трассировке указателей tail и head, а также значений, содержащихся в их ячейках?
Кажется, я тут что-то фундаментальное упустил, а понять не могу.

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
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
class query
{
protected:
    struct node
        {
        int V;
        node *next;
        node *prev;
        }*head,*tail;
public:
    query()//инициализация
        {
        head=new node;
        tail=new node;
        head->next=tail;
        tail->prev=head;
        head->prev=tail->next=NULL;
        }
    void empty ()//очистка списка
        {
        if (head!=tail)
        while (head!=tail)
            {
            tail=tail->prev;
            free (tail->next);
            }
        }
    int if_is_empty ()//проверка на пустоту
        {
        if (head==tail)
            return 1;
        else
            return 0;
        }
    void in_query (int x)//добавление элемента (с головы)
        {
            node *tmp=new node;
            tmp->next=NULL;
            tmp->prev=tail;
            tmp->V=x;
            tail=tmp;
        }
    int out_query ()//удаление элемента с хвоста, возврат его значения
        {
        int t=head->V;
        node *tmp=head;
        head=head->next;
        head->prev=NULL;
        free (tmp);
        return t;
        }
    void print ()//вывод
        {
        node *p;
        p=head;
        while (p!=tail)
            cout<<p->V<<" ";
        }
};
void main()
{
    query Q;
    clrscr();
    int x=1;
    for (;x;)
        {
        cin>>x;
        Q.in_query(x);
        }
    getch();
    Q.print();
    getch();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru