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

Распределение идентификаторов - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Метод Гаусса http://www.cyberforum.ru/cpp-beginners/thread452465.html
#include<stdio.h> #include<iostream.h> #include<conio.h> #include<stdlib.h> #include<malloc.h> // global variable declarations int nun,neq; double **sys,*back;
C++ Как правильно структурировать проэкт с++ ? Столкнулся с такой проблемкой, касающейся подключения заголовочных файлов в с++: Если посмотреть заголовочные файлы, к примеру пусть будет "name.h", в нём есть прототип некоторой ф-ции void f(); Следующий файл "b.cpp", в нём описание ф-ции f: void f() {} Скаченные проэкты с инета, например под VS6, к файлу main.cpp подключают только файл "name.h", и как бы у них всё работает, но стоит... http://www.cyberforum.ru/cpp-beginners/thread452453.html
C++ Как включить класс из внешнего файла в пространство имён?
У меня есть несколько .hpp файлов с объявлениями классов, типа этого: #ifndef EXPRESSION_HPP_INCLUDED #define EXPRESSION_HPP_INCLUDED template <class T> class expression { //Объявление класса } #endif // EXPRESSION_HPP_INCLUDED Я хочу их включить в одно пространство имен:
Задачи на структуры данных(стеки, очереди и т.д.) C++
НЕсколько задачек 1. Составить программу, которая формирует простую очередь желающих получить садик. Элементы очереди вводятся с клавиатуры и содержат следующие поля: ФИО ребёнка, дата рождения, адрес, телефон, наличие льгот. Программа должна предусматривать следующие функции: вывод всей очереди, удаление первого элемента, добавление нового элемента. 2. ...
C++ Составить функцию, которая возвращает N случайных неповторяющихся целых чисел из диапазона http://www.cyberforum.ru/cpp-beginners/thread452444.html
Помогите плизз Составить функцию, которая возвращает N случайных неповторяющихся целых чисел из диапазона . Главная программа задаёт P,Q,N и выводит на экран полученные N чисел.
C++ Алгоритм и программа обработки двоичного дерева. Помогите пожалуйста!!!)) Нужно написать программу на C++ Задание: определить количество узлов, у которых один сын. В соответствии с полученным заданием составить алгоритм и программу обработки двоичного дерева. подробнее

Показать сообщение отдельно
DariaLamb
Сообщений: n/a
25.02.2012, 13:46     Распределение идентификаторов
На входе файл с идентификаторами, я перевела все с року(string) и вызываю коструктор BinTree(string);. Дальше надо все идентификаторы распределить по бинарному дереву. А вот как понять не могу. Они все строковые, пыталась по разному. Помогите разобраться!
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
#include "stdafx.h"
#include <iostream>
#include <string>
#include <sstream>
#include <fstream>
#include <vector>
#include <algorithm>
#include <iterator>
#include <iterator>
using namespace std;
 
struct Tree
{
    int data;
    Tree *left, *right;
};
class BinTree
{
private:
    Tree *P1;
    Tree *head;
protected:
    int *massiv;    //  Массив чисел
    int number;         //  Количество чисел в массиве
public:
    BinTree();
    BinTree(string);        //  Ввод массива с окна
    ~BinTree();
    void Conversion(CString, vector<int>&); //  Преобразование строки в Массив чисел    
    void Print();       //  Вывод массива
    void InsertTree(string); //Заполнение
    void Insert(Tree *head, Tree *P1); //Распределение
};
 
BinTree::BinTree()
{
    P1=NULL;
    head=NULL;
}
BinTree::BinTree(string line)
{
    InsertTree(/*massiv, number*/line);
}
BinTree::~BinTree()
{
    delete []massiv;
}
void BinTree::Conversion(CString line, vector<int>&_vector)
{
    stringstream source(line.GetString());
    copy(istream_iterator<int>(source), istream_iterator<int>(), back_inserter(_vector));
}
void BinTree::InsertTree(string line)
{
    P1=new (Tree);
    string str="\0";
    for(int i=0;i<line.length();i++)
    {
        while(line!=" ")
        {
            str[i]=line[i];
            i++;
        }
        if(line==" ")
        {
            P1->data=str.size();
            P1->left=NULL;
            P1->right=NULL;
 
            if(head==NULL) head=P1;
            else Insert(head, P1);
        }
    }
}
void BinTree::Insert(Tree *head, Tree *P1)
{
    if (head->data>=P1->data)
    {
        if (head->left!=NULL)
            Insert(head->left, P1);
        else
            head->left=P1;
    }
    else
    {
        if (head->right!=NULL)
            Insert(head->right, P1);
        else
            head->right=P1;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:52. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru