Gardon和小希每天晚上都喜欢到屋外的森林里散步,设森林里有N块空地,任意两块空地之间都有一条小径相通。他们每次从任意一块空地出发,经过所有的空地后回到原来的空地。
由于他们都喜欢新鲜的旅行,所以他们不希望对任何一条小径经过两次。那么请问,他们最多能保证多少次这种新鲜的旅行呢?
例如(图),当N=5时,他们只能保持两次这样新鲜的旅行。
Input
输入包含多组数据,每组数据占一行,是一个数字 N。(0<N<=1000000000)
文件以一个0结束。
Output
对于每个输入的N,输出最多能保证新鲜旅行的次数。
Sample Input
5 0
Sample Output
2
刚看题时确实被数据吓到了,1000000000个数,每个数运算一次也超时了,于是我认为这个题是用不到算法和循环的;最后想要一个一个的数出来找规律;结果数六边形的时候还少话了一条边;也幸好少画一条边,才让我注意到,这题跟边有关;本来也想过数列的不过看多数据就放弃了;
解题思路:每条路只能走一次就表示一个来回这个原点至少要有两条边才能完成一个来回,而且任意两点联通就表示不用考虑走不完所有点的问题了;于是每个n边形有n-1条路径在原点,于是就有(n-1)/2次来回;解决;
代码就更简单了;
#include<stdio.h>
int main()
{
int m,n,i,j,k;
while(scanf("%d",&n),n!=0)
printf("%d\n",(n-1)/2);
return 0;
}