经典的一道递归题!解题思路如下:


假设n为最初始的空饮料瓶数,sum为已经喝的饮料瓶数。则有如下三种情况:

1) 当 n <= 1 时,就不能兑换了,直接 return sum;

2) 当 n == 2 时,根据题意可以多兑换一瓶饮料,sum += 1; return sum;

3) 当 n >= 3 时,一次性兑换的瓶子数为 tmp = n / 3;

                 兑换完之后剩余饮料瓶数为 rest = n % 3; 

                 rest还要加上兑换的瓶子数(已经喝完 为空) rest += tmp; 

                 这就是在一次兑换后剩余的瓶子数,然后递归调用,继续处理此时的rest。


参考代码如下:

#include <stdio.h>
#include <math.h>

int sum = 0;

int process(int n)
{
    int rest;
    int tmp;

    if (n <= 1)
    {
        return sum;
    }
    if (n == 2)
    {
        sum += 1;
        return sum;
    }
    if (n >= 3)
    {
        rest = n % 3;
        tmp = n / 3;
        sum += tmp;
        rest += tmp;
        process(rest);
    }
}

int main()
{
    int a[10];
    int i = 0;
    while (scanf("%d", &a[i]) != EOF && a[i] >= 1 && a[i] <= 100)
    {
        i++;
    }

    int j;
    int havedrinum;
    for (j = 0; j < i; j++)
    {
        havedrinum = process(a[j]);
        printf("%d\n", havedrinum);
        sum = 0; //每次处理完一个数据之后不要忘记把sum清零
    }

    return 0;
}


点赞(11)
 

0.0分

24 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 27 条评论

陈强 4年前 回复TA
不想让老板借瓶子给他
余哥 4年前 回复TA
#include<stdio.h>
int main()
{
	int r,a,b,p=0;
	int n[1000];
	int i=0;
	scanf("%d",&n[i]);
	while(n[i]&&n[i]<=100)
	scanf("%d",&n[++i]);
	i=0;
	while(n[i])
	{p=0;
	a=n[i]/3;
	b=n[i]%3;
	r=a+b;
	if(n[i]<2)
	p=0;
	else if(n[i]<=3)
	p=1;
	else
	{
		while(r>2)
		{p=p+a;
		a=r/3;
		b=r%3;
		r=a+b;}
		if(r==2)
		p+=2;
		else if(r==1)
		++p;
		
	}
	printf("%d\n",p);
	i++;
	}
	return 0;
 } 我这个为啥老是%50错误啊!,求大佬解答!
kgin 5年前 回复TA
#include <stdio.h>
int main (void)
{
   int n=10, sum, sum1, i, x;
   while (n--)
     {
     	 sum=0, sum1=0;
     	 scanf ("%d", &x);
     	 if(x==0)  break;
     	 while (x>2)
     	   {
     	   	    sum +=x/3;
     	   	    x=x/3+x%3;
		   } 
		 if(x==2)
		   sum++;
		 printf ("%d\n", sum);
	 }
	return 0;
}
肩膊 6年前 回复TA
@肩膊 那句话是加在后面的。。。。啊啊啊插错位置了。。。。。
肩膊 6年前 回复TA
#include <stdio.h>
int all;
int f(int n)
{
    int a;
    if(n >= 3)
    {
        a = n/3;
        all += a;
      return f(n - 2 * a);
    }

这几行就足够了其实
    else if(n == 2)
        return ++all;
    else
        return all;
}
int main(void)
{
    int n;
    while( scanf("%d",&n) && n)
    {
         all = 0;
         printf("%d\n",f(n));
    }

    return 0;
}
啊凯 6年前 回复TA
#include<stdio.h>
int sum=0;
int huanping(int a);
int main(void)
{
    int n[10];
    int i=0;
    while(scanf("%d",&n[i])!=EOF&&n[i]>0&&n[i]<=100)
    {
        i++;
    }
    for(int j=0;j<i;j++)
    {
        huanping(n[j]);
        printf("%d\n",sum);
    }
    return(0);
}
int huanping(int a)
{
    if(a==1)
    {
        return(0);
    }
    if(a==2)
    {
        sum++;
        return(0);
    }
    if(a>=3)
    {
        sum=sum+a/3;
        a=a%3+a/3;
        huanping(a);
    }
}
DQM 6年前 回复TA
除了程序格式有点差,其他都不错!