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

Вывод дерева, найти ошибку в коде - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как сделать динамический массив объектов? http://www.cyberforum.ru/cpp-beginners/thread1164310.html
IContainer *C = new myString; Есть такая запись, нужно сделать массив из C. IContainer *C = new myString; такое не работает, есть варианты или это невозможно? Добавлено через 2 минуты Далее мне нужно записывать
C++ Перекодировка из EBCDIC в win1251 Помогите пожалуйста составить прогу перекодировки файла из EBCDIC в win1251 http://www.cyberforum.ru/cpp-beginners/thread1164304.html
C++ Заменить каждое третье положительное число средним арифметическим отрицательных чисел, вывести в файл
Записать выходной файл, заменив каждое третье положительное число средним арифметическим отрицательных чисел. Дело в том, что я провел небольшой стресс-тест, к примеру: на первом и втором номере я ввел числа "+", на 3 номере число "-", на 4 номере число "+", в таком случае он мне должен был вывести на 4 номере среднее арифметическое, т.к. "каждое третье положительное", у нас же под 3-им...
Удвоить каждое слово во введённом предложении C++
Удвоить каждое слово во введённом предложении. На печать вывести введённую строку и результат её обработки.
C++ Найти количество одинаковых слов в строке http://www.cyberforum.ru/cpp-beginners/thread1164291.html
#include <iostream> using namespace std; int main() { char str1 = "to be or not to be"; char* leks = strtok(str1, " "); while(leks) // <====================================== {
C++ Рекурсия для вычисления суммы ряда Используя рекурсивный вызов функции вычислить с заданной точностью сумму ряда: 2/3+4/9+6/27+8/81+... (GUI) подробнее

Показать сообщение отдельно
Drosya12
0 / 0 / 0
Регистрация: 22.10.2013
Сообщений: 61

Вывод дерева, найти ошибку в коде - C++

02.05.2014, 19:51. Просмотров 275. Ответов 8
Метки (Все метки)

Ребятки,выручите,кто может,в общем,нужно,чтобы дерево вывелось,но не получается почему-то,где-то леплю смешную ошибку,программу полдня писал,уже голова не варит...Буду крайне благодарен за помощь
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
#define _CRT_SECURE_NO_WARNINGS
 
#include "windows.h"
#include "stdio.h"
#include "conio.h"
#include "math.h"
#include <locale.h>
 
struct tree //дерево как структура
{
    int info;           //информационнное поле
    tree *left, *right; //указатель на следующие элементы
};
typedef tree* ptree;
tree* createtree(int m) //заполнение дерева
{
    if (!m) return NULL;
    tree* root = new tree;
    printf("Введите элементы\n");
    scanf_s("%d", &root->info);
    root->left = createtree(m / 2);
    root->right = createtree(m - (m / 2) - 1);
    return root;
}
int showtree(tree *root) // лпк обход
{
    if (!root)
    {
        printf("введена полная фигня и такого дерева нет,извольте повторить,уважаемый \n");
        return 0;
    }
    if (root->left) showtree(root->left);
    if (root->right) showtree(root->right);
    return 0;
}
void PrintTreeLKP(ptree root, int deep) //демонстрация дерева
{
    if (root == NULL) return;
    PrintTreeLKP(root->left, deep + 1);
    for (int i = 0; i < deep; i++)
        printf(" ");
    printf("%d\n", root->info);
    PrintTreeLKP(root->right, deep + 1);
}
int deletetree(tree *root) //удаление дерева
{
    if (!root)
    {
        printf("дерева не существует\n");
        return 0;
    }
    delete[] root;
    return 0;
}
 
int main()
{
    int m = 0; //число элементов в дереве
    int n = 0; //нижняя граница интервала
    int k = 0; //верхняя граница интервала
 
    setlocale(LC_ALL, "Russian");
    printf("Задание:Написать программу, обеспечивающую работу со сбалансированным деревом:\n"); //вывод задания
    printf("1.Создание нового дерева из n элементов\n");
    printf("2.Просмотр дерева, очистка дерева\n");
    printf("3.Копирование инф. полей со значениями в диапазоне от n до k в массив\n");
    printf("4.Просмотр и очистку этого массива\n\n");
 
    printf("Введите количество элементов дерева:\n");
    scanf("%d", &m);
    tree* root = createtree(m);
    ptree treeRoot = NULL;
    printf("Ваше дерево, ЛПК обход:\n");
    PrintTreeLKP(treeRoot,0);
    _getch();
    return 0;
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru