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

Не ясен смысл функции. Деревья. - C++

Восстановить пароль Регистрация
 
JustMarcus
0 / 0 / 0
Регистрация: 19.12.2009
Сообщений: 3
09.06.2010, 16:28     Не ясен смысл функции. Деревья. #1
Доброго времени суток.
Не могу понять смысла функции F2.
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
#include <stdio.h>
 
struct tree
{
    int val;
    tree *child,*next; 
}
 
A={4,NULL,NULL},
B={8,NULL,&A},
C={3,&B,NULL},
D={7,NULL,&C},
E={10,&D,NULL},
F={2,NULL,&E},
G={1,&F,NULL},
*ph=&G;                             
 
int F1(tree *p) //количество вершин
{
    int n=1;
    for (tree *q=p->child; q!=NULL; q=q->next)
        n+=F1(q);    
    return n; 
}
 
int F2(tree *p, int l) //вот эта функция так и осталась для меня загадкой
{
    int n=l;
    for (tree *q=p->child; q!=NULL; q=q->next)
        n+=F2(q,l+1);
    return n; 
}
 
double main6(tree *p)
{
    return ((double)F2(p,1))/F1(p);
}
 
void main()
{
    double v=main6(ph);
    printf("%lf ",v);
}
В отладочном режиме увидел, что результат функции - 19. С чем связана эта цифра - непонятно.
А в финальном результате так вообще получается - 2,714286, от чего еще больше глаза лезут на лоб.

Как выглядит дерево:
Изображения
 
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.06.2010, 16:28     Не ясен смысл функции. Деревья.
Посмотрите здесь:

Смысл выражения x%2 C++
мне не ясен цикл do while C++
C++ Не ясен синтаксис.STL
C++ Смысл обьединений
C++ В чём смысл использования указателей на функции
Есть ли смысл помечать функции как inline, если их прототип уже есть в .h файле? C++
Не ясен код a^=b^=a^=b C++
Объясните, пожалуйста, смысл функции C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
promix_17
14 / 14 / 2
Регистрация: 12.05.2010
Сообщений: 43
09.06.2010, 19:51     Не ясен смысл функции. Деревья. #2
Это не функция, а просто ошибка программиста, наверное. В твоём конкретном случае она и должна 19 выдавать. Однако, если вместо int n=l; написать int n=1;, а от второго параметра избавиться, то будет выводиться количество рёбер дерева.
JustMarcus
0 / 0 / 0
Регистрация: 19.12.2009
Сообщений: 3
09.06.2010, 20:23  [ТС]     Не ясен смысл функции. Деревья. #3
Если поменять параметры, то она будет выводить количество вершин, но не количество ребер. А такая функция уже используется мной в другой работе. Не думаю, что в одном месте будут выложены две одинаковые функции.
Yandex
Объявления
09.06.2010, 20:23     Не ясен смысл функции. Деревья.
Ответ Создать тему
Опции темы

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