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

с++ Кольцо (контейнер), шаблоны, ромбовидное наследование - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа с текстовым файлом в Visual Studio http://www.cyberforum.ru/cpp-beginners/thread1025257.html
Программа компилится, но не может открыть файл studenti.txt. Куда этот файл точно кидать, что бы программа его находила? #include <stdio.h> #include <conio.h> #include <string.h> //libraries #include <windows.h> #include <iostream> #define N 20
C++ Поиск в глубину Помогите с заданием пожалуйста. Число 1 можно записать как сумму n чисел вида 1 / i, где i - натуральное число. Например, для n = 3 имеем 1 = 1/2 +1 / 4 +1 / 4. Найти способы записи числа 1 для заданного n методом поиска в глубину. http://www.cyberforum.ru/cpp-beginners/thread1025255.html
C++ Эвристика. Рюкзак Алладина.
Помогите с заданием пожалуйста. Разработать алгоритм и написать программу для задания Алладина: сколько ценных вещей (заданных массе и цене) может поместиться в рюкзак (заданный объем) Алладина.
C++ Составить функцию вычисления суммы
Прошу помощи, не понимаю, как записать числитель, что означает это троеточие? Заранее спасибо!
C++ Конвертация из heximal в int http://www.cyberforum.ru/cpp-beginners/thread1025243.html
Нужно написать функцию для конвертации строки, представленной как heximal, в int. Например: Вход: char * pStr = "0xFF"; Выход: int iRes = 255;
C++ Значение бесконечности для неизвестного типа Доброго времени суток, уважаемые эксперты! Просьба помочь с возникшим у меня вопросом: для решение некоторой задачи, мне приходится иметь в программе значение бесконечности float difference = std::numeric_limits<float>::max(); или float difference = std::numeric_limits<float>::infinity(); И это замечательно работает до тех пор пока я не выношу определение этой переменной в шаблон: ... подробнее

Показать сообщение отдельно
SentRAP2009
0 / 0 / 0
Регистрация: 18.04.2013
Сообщений: 29
02.12.2013, 04:38     с++ Кольцо (контейнер), шаблоны, ромбовидное наследование
Здравствуйте!
Нужна ваша помощь в c++. Дали задание организовать ромбовидное наследование и контейнер (кольцо). С первым проблем нет. А со вторым большие проблемы. Все написал, но вот ошибки с кольцом преследуют и именно проблемы с добавлением в кольцо. Помогите пожалуйста. Вот ссылка на архив с проектом http://yadi.sk/d/Fe_4cg6ZDdn4m

Добавлено через 22 минуты
Вот из файла Ring.h
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
#pragma once
#include <iostream>
 
template<typename T>
class Ring
{
private:
    struct RING
    {
        T Source;                                                               
        RING *l, *r;                                                                    
    };
    RING *first;
public:
    Ring();
    ~Ring();
    RING* Push(T& push, RING *ss)
    {
        if (first == NULL)
        {
            RING* t = (RING*)calloc(1, sizeof(RING));
            t->Source = push;
            t->l = t->r = t;
            return t;
        }
        else
        {
            RING *t = (RING*)calloc(1, sizeof(RING));
            t->Source = push;
            t->r = ss->r;
            t->l = ss;
            ss->r->l = t;
            ss->r = t;
            return t;
        }
    }
    RING* Push(T& ss)
    {
        return Push(ss, (first == NULL) ? first : first->r);
    }
    void Pop(RING *&pop);
    RING* Search(const T& search);
    T See(T see);
};
Вот из файла Ring.cpp

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
#include "Ring.h"
 
template<typename T>
Ring<T>::Ring()
{
    l = NULL;
    r = NULL;
    first = NULL;
}
 
template<typename T>
Ring<T>::~Ring()
{
    RING *ss = this->first;
    ss = ss->r;
    while(ss != ss->r)
    {
        Pop(ss);
        ss = ss->r;
    }
}
 
template<typename T>
void Ring<T>::Pop(RING *&ss)
{
    RING *ss1 = ss;
    int last = -1;
 
    if(ss == NULL)
    {
        cout << "\nОшибка удаления!!!\n";
        return;
    }
    if (ss == ss->r)
        last = 1;
    ss->l->r = ss->r;
    ss->r->l = ss->l;
 
    ss = ss->r;
    if (last == 1)
        ss = NULL;
    free(ss1);
}
 
template<typename T>
T Ring<T>::See(T see)
{
    return see;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru