rich22851716 2021-06-05 12:05 采纳率: 94.1%
浏览 14
已采纳

++数列:1,2,4,2,3,6,12,6,3,....求第n项值(递归)?

c++数列:1,2,4,2,3,6,12,6,3,....求第n项值(递归)

这道题我想了好久,没想出来,哪位大神能帮帮我?(我刚学c++)

代码也能贴出来吗?

  • 写回答

1条回答 默认 最新

  • 小P聊技术 2021-06-05 15:58
    关注
    #include <stdio.h>
    
    int fun(int n,int *x,int *y)
    {
    	int sum = 0,i;
    	int size = 0;
    	int dd = 1;
    	for (i = 1; i <= (*x);i++)
    	{
    		sum += (2*i-1);
    	}
    	if (sum == n)
    	{
    		*y = 2*(*x) -1;
    		return (*x);
    	}else if (sum > n)
    	{
    		(*y) = n - (sum - (2 * (*x) -1));
    		size = 2* (*x) -1;
    		dd = (*x);  //第x行的第一个数
    		for (i = 2; i <= (*y);i++)
    		{
    			if(i <= (*x))
    				dd *= 2;
    			else
    				dd /= 2;
    		}
    		return dd;
    	}else
    	{
    		(*x)++;
    		return fun(n,x,y);
    	}
    }
    
    int main()
    {
    	int n;        //n项(从第1项开始)
    	int row = 1,col = 0;
    	int val;
    
    	row = 1;
    	col = 0;
    	printf("请输入n:");
    	scanf("%d",&n);
    	val = fun(n,&row,&col);
    	printf("第%d项是:%d\n",n,val);
    	return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集
  • ¥15 在启动roslaunch时出现如下问题