问题描述:
Gardon和小希每天晚上都喜欢到屋外的森林里散步,设森林里有N块空地,任意两块空地之间都有一条小径相通。他们每次从任意一块空地出发,经过所有的空地后回到原来的空地。
由于他们都喜欢新鲜的旅行,所以他们不希望对任何一条小径经过两次。那么请问,他们最多能保证多少次这种新鲜的旅行呢?
例如(图),当N=5时,他们只能保持两次这样新鲜的旅行。
样例输入:
输入包含多组数据,每组数据占一行,是一个数字 N(0,1000000000]
文件以一个0结束。
5
0
样例输出:
对于每个输入的N,输出最多能保证新鲜旅行的次数。
2
思路:
每个顶点都有N - 1条边和它直接相连,一次旅行相当于要消耗与每个顶点相连的两条边,所以只需要计算N - 1能分成多少个两条边就可以得到结果。
AC代码:
#include <cstdio>
int main()
{
int N;
while(~scanf("%d", &N) && N != 0)
{
printf("%d\n", (N - 1) / 2);
}
return 0;
}