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;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题