取数位(蓝桥杯2017年试题E)

求一个整数的第k位数字有很多种方法,以下方法就是其中一种。

//求x用十进制表示时的数位长度

int len(int x){

if(x < 10) return 1;

return len(x/10) + 1;

}

//取x的第k位数字

int f(int x,int k){

if(len(x)-k==0) return x%10;

return _____________________________;//填空

}

int main()

{

int x = 23574;

printf("%d\n",f(x,3));

}

对于题目中的测试数据,应该打印5。

请仔细分析源码,并补充画线部分缺少的代码。

【参考答案】

f(x / 10,k)

【解析】

本题有3个函数,阅读程序首先从main函数开始。main函数中调用了f函数,而在f函数中调用了len函数。

首先要弄清楚len函数的功能,其功能是求x用十进制表示时的数位长度,然后要弄清楚f函数的功能,其功能是取x的第k位数字。

下面看 f函数,首先是

if(len(x) - k == 0) return x % 10;

分析该语句可知,如果当前x的数位长度刚好等于k,则直接对10求余。例如,要取345这个数的第三个数5,而345恰好又是3位数,那么只需要进行345%10便可以得出正确答案。

毫无疑问,下面要填空的是:如果当前x的数位长度不等于k,该如何处理?举例说明:假如要取数字34567的第3位数字5,而此时经过测量发现数字34567的长度为5,这与要取的3位数不相等,这时需要把数字34567变短再测试,变短的方式是除以10,即34567/10=3456,此时再比较,若发现还长,则继续变短,3456/10=345,345的长度与3相等,则第3位上的数字为5。

此过程可以利用递归形式表示出来,即f(x/10,k)。

【参考程序】

cpp 复制代码
#include <stdio.h>
int len(int x)
{
	if(x < 10) 
	 return 1;
	 return len(x / 10) + 1;	
}
//取x的第k位数字
int f(int x,int k)
{
	if(len(x) - k == 0)
	return x % 10;
	return f(x / 10,k);
 } 
int main(int argc, char** argv) {
	int x = 23574;
	printf("%d\n",f(x,3));
	return 0;
}

【运行结果如下】

相关推荐
小欣加油12 小时前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
_日拱一卒12 小时前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
郝学胜-神的一滴12 小时前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
小欣加油12 小时前
leetcode169 多数元素
数据结构·c++·算法·leetcode·职场和发展
酉鬼女又兒13 小时前
零基础入门虚拟局域网VLAN:从广播域问题根源到802.1q帧格式、三大端口类型及实战例题全解析
网络·网络协议·计算机网络·网络安全·职场和发展·智能路由器·求职招聘
AIHR数智引擎13 小时前
AI组织进化论:拆解微软、英伟达、Anthropic与Open AI如何重写组织
人工智能·经验分享·microsoft·职场和发展·aihr
我爱cope13 小时前
【Agent智能体24 | 规划-创建和执行LLM计划】
人工智能·设计模式·语言模型·职场和发展
小欣加油1 天前
leetcode2574 左右元素和的差值
数据结构·c++·算法·leetcode·职场和发展
千寻girling1 天前
一周没跑步了 ,今日跑步 5KM , 哑铃+健身 20min , 俯卧撑 30 个 ;
数据结构·c++·python·算法·leetcode·职场和发展·线性回归
8Qi81 天前
LeetCode 300 & 674:最长递增子序列 vs 最长连续递增子序列
算法·leetcode·职场和发展·动态规划