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

Сортировка массива чисел с использованием дерева - C++

Восстановить пароль Регистрация
 
Sobeardsocool
Сообщений: n/a
12.03.2014, 22:03     Сортировка массива чисел с использованием дерева #1
Всем привет, нужно осуществить сортировку массива, состоящего из чисел, с помощью дерева. То есть я просто создаю дерево, а потом обхожу его. Не так давно начал изучать C++, так что иногда действую очень по Pascal'евски. Вот проблема, при пошаговом проходе программы видно, что моя процедура ADD зацикливается, не могу понять, в чем дело. Возможно, не правильно передаю переменные в процедуры. Помогите, пожалуйста!)

Прилагаю код моей программы:


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
#include "stdafx.h"
#include <stdio.h>  
#include <conio.h>
#include <cstdlib>
#include <ctime>
#define n 10
 
struct tree
{
    tree* left; 
    tree* right; 
    int value;  
};
 
void ADD(tree* r, tree* pass){
    if (r == NULL) r=pass;
     else   
        if ((pass->value) < (r->value)) ADD(r->left, pass);
          else ADD(r->right, pass);
}
        
 
void TREE(tree* r){
    if (r != NULL){
        TREE(r->left);
        printf_s("%d", r->value);
        TREE(r->right);
    }   
}
 
void main(tree* r){
    tree* pass;
    int i, a[n],next_number;
    srand(time(0));
    puts("Ishodnaya stroka chisel :");
    r = NULL;
    for (i = 0; i < n; i++) { a[i] = rand() % 20 + 1; printf_s("%4d", a[i]);}
    next_number = a[0];
    while (!EOF){
        i += 1;
        pass = new (tree);
        pass->value = next_number;
        pass->left = NULL;
        pass->right = NULL;
        ADD(r, pass);
        i += 1;
        next_number = a[i];
    }
    puts("\n");
    TREE(r);
    _getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.03.2014, 22:03     Сортировка массива чисел с использованием дерева
Посмотрите здесь:

Ввод и сортировка массива комплексных чисел C++
C++ Сортировка с использованием рекурсии
Сортировка массива с использованием алгоритма стандартной библиотеки шаблонов Sort() C++
Двумерный массив рациональных чисел + среднее арифметическое чисел массива + сортировка методом вставки C++
C++ Сортировка массива случайных чисел
Сортировка массива, удаление простых чисел C++
Сортировка одномерного массива чисел C++
C++ сортировка и удаление чисел из массива

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 20:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru