自然数的任意位数字(递归版)

请编写函数,求自然数的任意一位数字。

函数原型

int Digit(int number, int index); 

说明:参数 number 为非负整数,index 为数位的索引号:个位编号为 0,十位编号为 1,百位编号为 2,...,以此类推。函数值为 number 的第 index 位数字。若 index 为负数,则函数值为 0。

裁判程序

#include <stdio.h>

int Digit(int number, int index);

int main()
{
    int n, i;
    scanf("%d%d", &n, &i);
    printf("%d\n", Digit(n, i));
    return 0;
}

/* 你提交的代码将被嵌在这里 */

测试数据

输入样例输出样例
0 00
35184 04
35184 18
35184 21
35184 35
35184 43
35184 50
35184 80
35184 -10
35184 30000000

要求:不得使用循环语句。

代码如下:

int Digit(int number, int index){
	int s;
    if(index<0 || number == 0)//首先写出限制条件
        return 0;
	if(index > 0){
		s = Digit(number/10,index-1);//number每轮去掉尾数,index每轮减一进行递归
	}
	else if(index == 0){
		s = number%10;//当index自减为0时,输出此时的尾数。
	}
	return s;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值