Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 12.12.2016
Сообщений: 3

Бинарная куча с использованием указателей

01.10.2017, 23:04. Показов 2209. Ответов 6

Студворк — интернет-сервис помощи студентам
Доброе время суток, форумчане. В качестве домашней работы было задано построить бинарную кучу с использованием массивов. Но за кучу с указателями был обещан бонус-балл, такие дела. Так вот хотелось бы показать, как я попробовал сделать, и узнать о возможных (в моем случае тем более) ошибках

Java
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
import java.util.Stack;
 
public class HeapTree{
    class Node{
        Node left, right, parent;
        int value;
        int index;
        public Node(int value){
            this.value = value;
        }
        public Node(){}
    }
    Node head;
    Node last;
    int size;
 
 
    public HeapTree()
    {
 
        head = null;
        last = null;
    }
    public static String toBinary(int int1){
        return (Integer.toBinaryString(int1));
    }
    public void insert( int value){
        if ( head == null)
        {
            head = new Node(value);
            head.left = null;
            head.right = null;
            head.parent = null;
            size++;
            return;
        }
        Node temp = head;
        String word = toBinary(size+1);
        for ( int i =1; i < word.length(); i++)
        {
            if (temp.right == null || temp.left == null)
            {
                if(word.charAt(i)=='0'){
                    temp.left = new Node(value);
                    temp.left.parent = temp;
                    bubbleUp(temp.left);
                }
                else {
                    temp.right = new Node(value);
                    temp.right.parent = temp;
                    bubbleUp(temp.right);
                }
                size++;
                return;
            }
            if(word.charAt(i)=='0'){
                temp = temp.left;
            }
            else temp = temp.right;
        }}
 
 
    public Node findNode(int number){
        Node temp = head;
        String word = toBinary(number);
        for ( int i =1; i < word.length(); i++)
        {
            if(word.charAt(i)=='0'){
                temp = temp.left;
            }
            else temp = temp.right;
        }
        return temp;
    }
    public void print(Node head)
    {
        Node temp = head;
        if (temp!=null)
        {
            System.out.println(temp.value);
            print(temp.parent);
        }
    }
    public void bubbleUp(Node head)
    {
        Node temp = head;
        while (temp.parent!=null)
        {
            if (temp.value >= temp.parent.value)
            {
                return;
            }
            if ( temp.value < temp.parent.value){
                swap(temp, temp.parent);
            }
            temp = temp.parent;
        }
    }
 
    public void swap(Node temp, Node parent) {
        int tempNum = temp.value;
        temp.value = parent.value;
        parent.value = tempNum;
    }
    public void deleteMin(){
 
        Node temp = findNode(this.size);
        head.value = temp.value;
 
        if(this.size%2==1)
            {
                temp.parent.right = null;
            }
        else
            {
            temp.parent.left = null;
            }
        sinkDown();
        size--;
    }
    public void sinkDown(){
        Node temp = head;
        while(true){
            if(temp.left == null){
                return;
            }
            else if (temp.right == null){
                if (temp.value > temp.left.value)
                swap(temp, temp.left);
                return;
            }
 
 
            if (temp.value <= temp.right.value && temp.value <=temp.left.value ) return;
 
            if (temp.left.value < temp.right.value)
            {
                swap(temp, temp.left);
                temp = temp.left;
            }
            else {swap(temp, temp.right); temp = temp.right;}
 
        }
 
        }
 
 
    public static void main ( String args[])
    {
        HeapTree heapTree = new HeapTree();
        heapTree.insert(35);
        heapTree.insert(33);
        heapTree.insert(42);
        heapTree.insert(11);
        heapTree.insert(52);
        heapTree.insert(22);
        heapTree.insert(66);
       
        System.out.println(heapTree.head.value);
        System.out.println(heapTree.head.left.value);
        System.out.println(heapTree.head.right.value);
        System.out.println(heapTree.head.left.left.value);
        System.out.println(heapTree.head.left.right.value);
        System.out.println(heapTree.head.right.left.value);
        System.out.println(heapTree.head.right.right.value);
 
 
    }}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.10.2017, 23:04
Ответы с готовыми решениями:

"Бинарная куча" не работает
Написал я, значит, черновик структуры данных - бинарная куча. Только она, как водится не работает. Переменная SizeHeap, которая отвечает за...

программа с использованием указателей
Найти произведение всех элементов массива A={a}, совпадающих с его первым элементом. Использовать динамическое выделение памяти.

Переделать с использованием указателей
Прошу помощи у разбирающихся людей. Есть 2 задания. Надо переделать с использованием указателей как можно проще..Буду очень признателен в...

6
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
02.10.2017, 08:56
Цитата Сообщение от abylkasymov Посмотреть сообщение
Но за кучу с указателями был обещан бонус-балл
жаль что в джава указателей нет, так что бонус балла можете не ждать)
0
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
02.10.2017, 09:54
abylkasymov, вообще-то неразумно для кучи использовать дерево, она в обычном массиве хранится должна
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
02.10.2017, 10:35
Цитата Сообщение от woldemas Посмотреть сообщение
abylkasymov, вообще-то неразумно для кучи использовать дерево, она в обычном массиве хранится должна
обоснуй
0
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
02.10.2017, 10:41
Лучший ответ Сообщение было отмечено abylkasymov как решение

Решение

Цитата Сообщение от xoraxax Посмотреть сообщение
обоснуй
Удобная структура данных для сортирующего дерева — массив A, у которого первый элемент, A[1] — элемент в корне, а потомками элемента A[i] являются A[2i] и A[2i+1] (при нумерации элементов с первого). При нумерации элементов с нулевого, корневой элемент — A[0], а потомки элемента A[i] — A[2i+1] и A[2i+2].
Взято отсюда: https://ru.wikipedia.org/wiki/... 1%87%D0%B0
0
0 / 0 / 0
Регистрация: 12.12.2016
Сообщений: 3
02.10.2017, 16:07  [ТС]
Да, Вы правы, но все же обьекты в Java могут быть использованы как указатели, так как у них тип reference, насколько я знаю. И как в с++ можно написать
C++
1
2
3
4
 struct Node {
 Node*left;
 Node *right;
 int value;}
в Java можно создать класс
Java
1
2
3
4
 
class Node{
 Node right, left;
 int value;}
0
 Аватар для Kukstyler
1260 / 870 / 268
Регистрация: 02.04.2009
Сообщений: 3,307
02.10.2017, 16:26
Лучший ответ Сообщение было отмечено abylkasymov как решение

Решение

Цитата Сообщение от abylkasymov Посмотреть сообщение
обьекты в Java могут быть использованы как указатели
Java работает только by reference, то есть по адресам. Но в Java нет понятия указателя (мы не можем напрямую работать с памятью), а есть понятие ссылки (т.к. by reference). Ссылка - это (технически) указатель, но константный.

Думаю, для здорового мышления в Java, лучше забыть про указатели, как таковые.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.10.2017, 16:26
Помогаю со студенческими работами здесь

Программа с использованием указателей
Информатика... Будь она неладна... Задали - написать программу с использованием указателей. Я эту тему не понимаю, сколько ни читал и не...

Очередь с использованием указателей
Необходимо в С# создать очередь с помощью указателей (не встроенные возможности использовать, а самостоятельно сделать). Только начинаю...

Решения на С с использованием указателей
Поиогите пожалуйсто с решением одной задачки,очень надо.Сама в С ничего не понимаю:sorry: Дан массив координат 30 точек на...

Пррограмма с использованием указателей
Найти произведение квадратов первых k элементов массива A={a}, удовлетворяющих условию a&gt;=c+d. Использовать динамическое выделение памяти

Преобразовать с использованием указателей
#include &lt;iostream&gt; #include &lt;string&gt; int main() { std::string first, second; std::cout &lt;&lt; &quot;Enter first month and...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Функция установки текстового статуса в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru