Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C++ Функция sprinf() https://www.cyberforum.ru/ cpp-beginners/ thread452203.html
Пишу прогу на WINAPI нужно преобразовать масив чисел в строку, чтоб вивести ево, вот врагмент для консоли: char Name; for(i = 0; i < N; i++) { for(j = 0; j < N; j++) { sprintf(Name, " %d", cells ); }
Union C++
Возник вопрос про объединения. В книгах я встречал лишь случай, когда размер одного из полей больше или равен сумме размеров остальных. Например: union { double a; char b; }; А как будет работать объединение в таком случае:
C++ Практика по с++ https://www.cyberforum.ru/ cpp-beginners/ thread452183.html
1)Дан массив целых чисел. Найти в этом массиве минимальный элемент m и максимальный элемент M. Получить в порядке возрастания все целые числа из интервала (m;M), которые не входят в данный массив 2)Дана матрица размером n x m. Переставляя ее строки и столбцы, добиться того, чтобы наибольший элемент (или один из них) оказался в верхнем левом углу. 3)Дана строка. Определить, сколько раз входит в...
C++ Матрица в классе, указатель на матрицу. Здравствуйте. Помогите, пожалуйста, с матрицей в классе. Вот то, что накалякал я. Matrix.h: class Matrix{ private: int n,m; double *arr; public: Matrix(int, int); void setMatrix(); ~Matrix(); https://www.cyberforum.ru/ cpp-beginners/ thread452170.html
Имеется N мужчин и N женщин. Имеются также данные о предпочтениях каждого мужчины к каждой женщине. C++
Имеется N мужчин и N женщин. Имеются также данные о предпочтениях каждого мужчины к каждой женщине. Аналогичные данные имеются и для женщин. Требуется составить такой набор пар, чтобы общество, получившееся из таких семей, было наиболее «счастливо». (Исходные данные задать самостоятельно).
C++ Ввод аргументов командной строки Здравствуйте, такой вопрос: как задаются аргументы командной строки в си? нужно скомпилировать exe и запустить его через командную строку ОС, а после имени файла указать нужные мне аргументы? можно ли это сделать сразу в самой среде(в частности netbeans)? надеюсь более менее понятно написал... https://www.cyberforum.ru/ cpp-beginners/ thread452158.html
C++ Перевод https://www.cyberforum.ru/ cpp-beginners/ thread452155.html
Здравствуйте , помогите перевести прогу с паскаля на с++. Это метод Гаусса. Буду благодарен uses CRT; Const maxn = 10;
C++ 3 задачки по с++
ребят выручайте нужно срочно сделать 3 задачки по с++ из 10 не могу сделать только их... выручайте делать нужно в Borland C++ на библиотеках conio и iostream 1.дан двумерный массива размерностью N*N. Найти сумму модулей элементов, расположенных ниже главной диагонали. 2. Двумерный массив задан последовательностью случайных чисел от 0 до М. Размерность массива определяется...
C++ Кусочные функции (не пойму в чем ошибка) Создать программу для вычисления значений функции в соответствии с заданным варианта. #include <iostream.h> #include <math.h> int main() { double x; double y; double z; https://www.cyberforum.ru/ cpp-beginners/ thread452146.html C++ Размер файла... https://www.cyberforum.ru/ cpp-beginners/ thread452145.html
Ищу функцию которая возвращает размер файла в строковом виде... Например: 4 -4 б 1041 - 1,017 Кб и.т.д.
C++ Операция ИЛИ
Добрый вечер) Я новичок в СИ поэтому если вопрос глупый не пинайте) Возможно ли сделать подобную операцию в СИ: IF (a == 3 ИЛИ 4) { if (b == 5 ИЛИ 6 ) {c = 1;} else {c = 0;};} Тоесть если "а" соответствует трём или четырём, а "b" соответствует пяти или шести. Как я понял после долких мук, операция "||" этого сделать не может.
C++ Перекидывание значений из массива в массив Здравствуйте. У меня проблема с массивом, в который почему-то не сохраняются значения. В результате этого кода: float img; int l=0; for (int i = 0; i < 6; i++) { for (int j = 0; j < 6; j++) https://www.cyberforum.ru/ cpp-beginners/ thread452128.html
2 / 2 / 0
Регистрация: 30.10.2011
Сообщений: 16
0

задача с деревьями(надо найти ошибку) - C++ - Ответ 2523511

25.02.2012, 18:35. Показов 587. Ответов 0
Метки (Все метки)

Author24 — интернет-сервис помощи студентам
Найти вершины, через которые проходят пути максимальной длины, и удалить (правым удалением) самую высокую из них их.
Входные данные
in.txt содержит последовательность чисел — ключей дерева.
Выходные данные
out.txt содержит массив вершин, полученный прямым левым обходом итогового дерева.
вот такая задача. я написал вот такой код, но он не работает. не могу понять где ошибка(( подскажите )
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
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
#include <iostream>
#include <fstream>
using namespace std;
 
struct Tree
{
    int Key;
    Tree* LeftSon;
    Tree* RightSon;
    int L;
    int R;
};
 
void Output(Tree* a, ofstream &file)
{
    if (a != NULL)
    {
        file << a -> Key << '\n';
        Output (a -> LeftSon, file);
        Output (a -> RightSon, file);
    }
}
 
void Input(ifstream &file, Tree* derevo)
{
    char c[100];
    file.getline (c,100);
    derevo -> Key = atoi (c);
    while (! file.eof())
    {
        file.getline (c,100);
        Tree* t = new Tree;
        t -> LeftSon = NULL;
        t -> RightSon = NULL;
        t -> L = 0;
        t -> R = 0;
        t -> Key = atoi (c);
        Tree* temp = derevo;
        bool k = false;
        while ( k == false)
        {
            if (t -> Key < temp -> Key)
                if (temp -> LeftSon != NULL)
                    temp = temp -> LeftSon;
                else
                {
                    temp -> LeftSon = t;
                    k = true;
                }
            else if (t -> Key > temp -> Key)
                if (temp -> RightSon != NULL)
                    temp = temp -> RightSon;
                else
                {
                    temp -> RightSon = t;
                    k = true;
                }
            else if (t -> Key == temp -> Key)
            {
                delete t;
                k = true;
            }
        }
    }
}
 
int max (int a, int b)
{
    return (a > b) ? a : b;
}
 
int Obhod(Tree* derevo, int Max)
{
    if (derevo != NULL)
    {
        Obhod (derevo -> LeftSon, Max);
        if (derevo -> LeftSon != NULL)
            derevo -> L = max (derevo -> LeftSon -> L, derevo -> LeftSon -> R) + 1;
        Obhod (derevo -> RightSon, Max);
        if (derevo -> RightSon != NULL)
            derevo -> R = max (derevo -> RightSon -> L, derevo -> RightSon -> R) + 1;
        if ((derevo -> L + derevo -> R  > Max))
        {
            Max = derevo -> L + derevo -> R;
        }
    }
    return derevo -> Key;
}
 
bool DeleteEl (Tree* derevo, int del )
{
    if ( derevo == NULL ) return false;
    if ( derevo -> Key == del )
    {
        if((derevo -> LeftSon != NULL) && (derevo -> RightSon != NULL))
        {
            Tree* derevo1 = derevo -> RightSon;
            if(derevo1 -> LeftSon == NULL)
            {
                derevo -> Key = derevo1 -> Key;
                derevo -> RightSon = derevo1 -> RightSon;
                delete derevo1;
            }
            else
            {
                while (derevo1 -> LeftSon -> LeftSon != NULL) 
                    derevo1 = derevo1 -> LeftSon;
                derevo -> Key = derevo1 -> LeftSon -> Key;
                derevo1 -> LeftSon = NULL;
                delete derevo1 -> LeftSon;
            }
            return false;
        } else
            return true;
    }
    if (DeleteEl(derevo -> RightSon, del))
    {
        if (derevo -> RightSon -> RightSon == NULL )
            derevo -> RightSon = derevo -> RightSon -> LeftSon;
        else
            derevo -> RightSon = derevo -> RightSon -> RightSon;
        delete derevo -> RightSon;
        return false;
    }
    if (DeleteEl(derevo -> LeftSon, del))
    {
        if ( derevo -> LeftSon -> RightSon == NULL )
            derevo -> LeftSon = derevo -> LeftSon -> LeftSon;
        else
            derevo -> LeftSon = derevo -> LeftSon -> RightSon;
        delete derevo -> LeftSon;
        return false;
    }
    return false;
}
int main()
{
    int  Max(0);
    ifstream f1;
    ofstream f2;
    f1.open ("in.txt");
    f2.open ("out.txt");
    Tree* derevo = new Tree;
    derevo -> LeftSon = NULL;
    derevo -> RightSon = NULL;
    derevo -> L = 0;
    derevo -> R = 0;
    Input(f1, derevo);
    int temp=Obhod(derevo, Max);
    DeleteEl (derevo, temp);
    Output(derevo, f2);
    return 0; 
}
Добавлено через 1 час 15 минут
вся проблема в функции Input(скорее всего).

Добавлено через 19 часов 7 минут
ща посмотрел код,пришел к выводу, что не в input ошибка, а Obhod.

Вернуться к обсуждению:
задача с деревьями(надо найти ошибку) C++
0
Заказать работу у эксперта
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.02.2012, 18:35
Готовые ответы и решения:

задача с деревьями на прологе
Помогите пожалуйста решить задачу с деревьями на прологе: Определить число вхождений элемента Е в...

Надо найти ошибку
Задача: дан массив, требуется найти два равных в нем элемента и вывести их индексы. Есть логически...

Надо найти ошибку
Вот задача Составить программу, удаляющую одну цифру из N-значного числа, такую, чтобы...

надо найти ошибку
program ZADACA2_1; uses crt; var H:text; P,Pn,Pk,hP:integer; V,Vn,Vk,hV:real;...

0
25.02.2012, 18:35
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.02.2012, 18:35
Помогаю со студенческими работами здесь

Надо найти ошибку...
Добрый день, дорогие программисты! Пишу курсач &quot;Преломление/отражение света в воде, стекле, масле&quot;...

Надо найти ошибку
Отдельные буквы русского алфавита, слова, фразы. Свойства: шрифт, размер, стиль (полужирный,...

Надо найти ошибку
Всем привет! Вот задали задачку, решаю, а не выходит точно, можно сказать вообще не правильно...

С++ задача, надо зациклить, скажите что не так, ошибку выдает в switch, про точку с запятой знаю их вроде не н
{ do { char c; system(&quot;echo Есть три задачи&quot;); system(&quot;echo 1-Следование&quot;);...

0
Новые блоги и статьи
Что такое хорошо и что такое плохо, вид сбоку. Индивид и общество - грань не нарушения.
Hrethgir 18.01.2025
В моей личной жизни и времени, я рассуждаю категорией "хуже-лучше", в том плане, когда меня спросили например - "а зачем ты делаешь свой процессор?", то я ответил - "чтобы сделать свою жизнь лучше". . .
Передача по ссылке или по значению в Java?
InfoMaster 18.01.2025
В мире программирования на Java одним из ключевых аспектов, требующих глубокого понимания, является механизм передачи параметров в методы. Этот фундаментальный концепт часто становится источником. . .
Тернарный условный оператор в Python
InfoMaster 18.01.2025
В мире программирования существует множество инструментов и конструкций, позволяющих создавать эффективный и лаконичный код. Одним из таких инструментов является тернарный условный оператор, который. . .
Как удалить неотслеживаемые файлы из рабочего дерева Git
InfoMaster 18.01.2025
В процессе разработки программного обеспечения с использованием системы контроля версий Git часто возникает необходимость в управлении неотслеживаемыми файлами. Неотслеживаемые файлы (untracked. . .
Что делает код if __name__ == "__main__": в Python
InfoMaster 18.01.2025
В мире программирования на Python существует множество важных концепций, и одной из наиболее интересных является конструкция if __name__ == "__main__". Эта специальная конструкция играет ключевую. . .
Как заставить Git забыть об отслеживаемом файле, добавленном в .gitignore
InfoMaster 18.01.2025
В мире разработки программного обеспечения система контроля версий Git стала неотъемлемой частью рабочего процесса, позволяя эффективно отслеживать изменения в коде и управлять ими. Однако. . .
Что означает use strict в JavaScript и для чего используется
InfoMaster 18.01.2025
В мире современной веб-разработки JavaScript играет ключевую роль как один из основных языков программирования. По мере его эволюции возникла необходимость в механизмах, которые помогли бы. . .
Как работать со скрытыми (hidden) элементами в jQuery
InfoMaster 18.01.2025
В современной веб-разработке управление видимостью элементов на странице является одним из ключевых аспектов создания интерактивных пользовательских интерфейсов. jQuery предоставляет мощный набор. . .
Как переключаться между ветками (Branch) с помощью checkout в Git
InfoMaster 18.01.2025
Ветки в Git являются одной из ключевых концепций для управления версионностью кода, позволяя разработчикам эффективно работать в команде и параллельно развивать программные проекты. Каждый новый. . .
Что такое стек и куча, чем они отличаются и где находятся
InfoMaster 18.01.2025
Понимание основных концепций памяти в программировании В мире современного программирования эффективное управление памятью играет ключевую роль в создании производительных и надежных приложений. . . .
Как использовать комментарии в JSON
InfoMaster 18.01.2025
JSON (JavaScript Object Notation) представляет собой легкий и широко используемый формат обмена данными, который стал стандартом де-факто для веб-приложений и программных интерфейсов. При работе с. . .
Как заставить git pull перезаписать локальные файлы в Git
InfoMaster 18.01.2025
Проблема перезаписи локальных файлов в Git При работе с системой контроля версий Git разработчики часто сталкиваются с ситуацией, когда необходимо синхронизировать локальный репозиторий с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru