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

Проверка существования структуры - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вычислить сумму ряда http://www.cyberforum.ru/cpp-beginners/thread409992.html
.Вычислить сумму ряда \sum_{k=o }^{\propto }\left(-1{k}^{} \right)\frac{x{}^{2k}}{(2k)!} с точностью до 10 в -5 степени.Построить таблицу для х=0;0.1;0.2....0.9;1;0.Проверить значения по функции cos(х)
C++ Поразрядная сортировка Доброе время суток, написал программу поразрядной сортировки по определенному критерию должно сортировать, проблем в логике вроде бы не должно быть, но вот проблема в функции yy в том что не хватает выделения памяти для mask. даже при присвоение типа unsigned long long выходит за предел . Подскажите в чем причина и как с ней бороться #include <iostream> #include <algorithm> #include <vector>... http://www.cyberforum.ru/cpp-beginners/thread409979.html
C++ сумма диагоналей???
Вот в чем вопрос! Вроде все правильно, но сумму неправильно вычисляет, а именно нужно: Найти максимальную, из всех сумм диагоналей, параллельных главной! #include <iostream> #include <iomanip> #include <cmath> using namespace std; // Прототип для ввода двумерного массива int** inputm (int n); // Прототип для вывода двумерного массива void outputm (int** a, int n);
C++ Разработать алгоритм обработки двумерного массива
Разработать алгоритм обработки двумерного массива размера n*m. Числа m и n, а также элементы массива взять из файла. Необходимо каждый элемент массива увеличить на сумму элементов его строки. результат записать в другой файл. пожалуйста помогите очень нужно!!
C++ Абстрактны классы http://www.cyberforum.ru/cpp-beginners/thread409940.html
Здравствуйте, форумчане! у меня вот такая вот задача! Разработать класс список как абстрактный базовый класс с интерфейсом - сохранить и восстановить. Создать производные классы стек и очередь с реализованными интерфейсами восстановить и вытащить. обычные абстрактные классы у меня получается создавать! на пример на задачу : Разработать абстрактный класс - форма с интерфейсом площадь,...
C++ Упорядочить строки матрицы в порядке неубывания их первых элементов Всем привет! Помогите пожалуйста решить задачу, хз как делать :) Дана матpица A. Упорядочить строки матрицы в порядке не убывания их первых элементов. Всё чnо я смог, это вывести исходную матрицу на экран, и все :DDD Заранее спасибо ! // задача // #include "stdafx.h" #include <stdlib.h> #include <stdio.h> подробнее

Показать сообщение отдельно
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
18.12.2011, 22:37     Проверка существования структуры
Особо не вникал в проблему, но вот по деревьям
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
typedef struct link
{
    int key;
    link *left;
    link *right;
} node;
 
node * search (node * tree, int key)
{
    node *buf;
    
    if (tree)
        do
        {
            buf=tree;
            if (tree->key==key)
                return NULL;
            if (key<tree->key)
                tree=tree->left;
            else
                tree=tree->right;
        } while (tree);
 
        return buf;
}
 
int Add (node **tree, int key)
{
    node * buf;
 
    if (!  ( buf = (node *) malloc ( sizeof (node) ) )  )
    {
        printf ("\nNo free memory");
        return -1;
    }
    buf->key=key;
    buf->left=NULL;
    buf->right=NULL;
 
 
    if (!*tree)
    {
        *tree=buf;
        return 1;
    }
 
    if (search(*tree,key))
    {
        if (key<search(*tree,key)->key)
            search(*tree,key)->left=buf;
        else 
            search (*tree,key)->right=buf;
    }
    else 
        return -1;
 
    return 0;
}
 
 
void iteration (node * root)
{
    if (root)
    {
        printf ("%5d", root->key);
        iteration (root->left);
        iteration (root->right);
    }
}
 
void del (node **root, int value)
{
    if (!*root)
    { 
        printf ("No key\n");
        fflush (stdin);
        getch ();
        return ;
    }
    
    if (value < (*root)->key)
        del (&(*root)->right,value);
    else 
        if (value > (*root)->key)
            del (&(*root)->right,value);
        else
        {
            node *buf=(*root)->left;
            node *t =(*root)->right;
            free (*root);
            *root=t;
            
            while (*root)
                root = &(*root)->left;
            
            *root = buf;
        }
}
 
int main(int argc, char* argv[])
{
    node *tree=NULL;
    int key;
    
        Add (&tree,key); // Добавление
 
        iteration (tree); // Обход
        
        del (&tree, key); // Удаление
 
        system ("pause");
    return 0;
}
 
Текущее время: 14:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru