菜鸟刷题Day4
创始人
2025-06-01 08:19:09
0

⭐作者:别动我的饭
⭐专栏:菜鸟刷题
⭐标语:悟已往之不谏,知来者之可追
在这里插入图片描述

一.阶乘尾数:面试题 16.05. 阶乘尾数 - 力扣(LeetCode)

描述

设计一个算法,算出 n 阶乘有多少个尾随零。


解题思路

1.先求出n的阶乘然后不断的模十除十得到尾数,要注意零要从最后一位数开始连续,一旦不连续就结束了。老实人解法,我不提倡。


2.尾数0是怎么来的?不就是2*5=10;所以只需要统计2 * 5的出现的次数即可,有2不一定有5,但是有5一定有2。所以只需要统计5出现的次数就行(注意:一个数中如果含有多个5,只算一次)。

比如:20!=1 * 2 * 3 * 4 * 5……* 10……* 15……* 20;

这个式子中出现了5,10=2 * 5,15=3 * 5,20=4 * 5;

即出现了4个5,而20的阶乘为243290200817664 0000;尾数零刚好是4个

找5的个数,也就是将n循环除5直到小于5为止

int trailingZeroes(int n)
{int count=0;while(n>=5)//n小于5是没有尾数0的{count+=n/5;n/=5;}}

二.取近似值:取近似值_牛客题霸_牛客网 (nowcoder.com)

描述

写出一个程序,接受一个正浮点数值,输出该数值的近似整数值。如果小数点后数值大于等于 0.5 ,向上取整;小于 0.5 ,则向下取整。

数据范围:保证输入的数字在 32 位浮点数范围内


解题思路

如果一个浮点数的小数位大于0.5,也就是说给这个浮点数再加上0.5这个数的个位就会向上自增1。再将这个数赋值给一个整形变量,就可以拿到这个数向上取整的结果。(整形是向下取整的,无论小数位是多少都是向下取整)

浮点数直接以整数的形式输出具有不确定性,所以用一个整形临时变量作为中转站

#includeint main()
{float f=0;scanf("%f",&f);int tmp=f+0.5;printf("%d\n",tmp);return 0;
}

三.数列:数列_牛客题霸_牛客网 (nowcoder.com)

描述

某种特殊的数列a1, a2, a3, …的定义如下:a1 = 1, a2 = 2, … , an = 2 * an − 1 + an - 2 (n > 2)。给出任意一个正整数k,求该数列的第k项模以32767的结果是多少?

输入描述:

第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,包括一个正整数k (1 ≤ k < 1000000)。


解题思路

1.我最开始是想以类似于求斐波那契数那样的思想来做,但是会运行超时。不过既然提到了,这里也放上代码,毕竟求斐波那契数也是一道经典的题目。

#includeint main()
{int f1=1;int f2=2;int f3=0;int n=0;scanf("%d",&n);while(n--){int k=0;scanf("%d",&k);for(int i=0;if3=2*f2+f1;f3%=32767;//防止溢出,可以只存放模以后的结果//迭代f2=f3;f2=f1;}printf("%d\n",f3);}return 0;
}

2.以上那种方法会运行超时。这里可以利用数组来优化一下,既然题目中说明了k<1000000,那就开辟一个这么大的数组,先循环将取模的结果存放到数组中,以后只要根据k的值来数组取元素即可。

#includeint main()
{int arr[1000000]={1,2};for(int i=2;i<1000000;i++){arr[i]=2*arr[i-1]+arr[i-2];arr[i]%=32767;}int n=0;scanf("%d",&n);while(n--){int k=0;scanf("%d",&k);printf("%d\n",arr[k-1]);}return 0;}

四.统计字符:统计字符_牛客题霸_牛客网 (nowcoder.com)

描述

输入一行字符,分别统计出包含英文字母、空格、数字和其它字符的个数。

数据范围:输入的字符串长度满足 1 ≤ n ≤1000

输出描述:统计其中英文字符,空格字符,数字字符,其他字符的个数


解题思路

这种题目我只能当老实人了,创建一个数组,然后将数组赋值给一个字符指针,然后对取到的字符做判断。如果各位有更好的办法可以评论区留言(毕竟博主现在是个菜鸡(畏畏缩缩))

#include
#includeint main()
{char *str[1001];while(gets(str)>0)//gets的返回值是整形{char *s=str;int blank=0;//空格int num=0;//数字int letter=0;//字母int other=0;//其他while(*s!='\0'){if(*s>='a'&&*s<='z'||*s>='A'&&*s<='Z'){letter++;}else if(*s==' '){blank++;}else if(*s>='0'&&*s<='9'){num++;}else{other++;}s++;}printf("%d\n%d\n%d\n%d\n",letter,blank,num,other);}return 0;
}

人们总是高估短期努力带来的提升,而忽略长期坚持带来的改变。今天是第四天,你还有在坚持吗?

相关内容

热门资讯

安卓共有多少种系统,究竟有多少... 你有没有想过,安卓这个我们每天不离手的操作系统,竟然有那么多不同的版本呢?没错,安卓系统就像一个大家...
安卓系统怎么播放swf,And... 你有没有遇到过这种情况:手里拿着一部安卓手机,想看一个SWF格式的动画,结果发现怎么也打不开?别急,...
pos机安卓系统跟win系统,... 你有没有想过,那些在我们生活中默默无闻的POS机,竟然也有自己的操作系统呢?没错,就是安卓系统和Wi...
俄罗斯封禁安卓系统,本土化替代... 俄罗斯封禁安卓系统的背后:技术、经济与社会的影响在数字化浪潮席卷全球的今天,智能手机已成为我们生活中...
安卓系统总是弹出权限,安卓系统... 手机里的安卓系统是不是总爱和你玩捉迷藏?每次打开一个应用,它就跳出来问你要不要给它开权限,真是让人又...
安卓系统测血氧,便捷健康生活新... 你知道吗?现在科技的发展真是让人惊叹不已!手机,这个我们日常生活中不可或缺的小玩意儿,竟然也能变身成...
蓝光助手安卓系统的,深度解析与... 你有没有发现,现在手机屏幕越来越大,看视频、刷抖音,简直爽到飞起!但是,你知道吗?长时间盯着屏幕,尤...
安卓系统如何隐藏提示,Andr... 你是不是也和我一样,在使用安卓手机的时候,总是被那些弹出来的提示信息打扰到?别急,今天就来教你怎么巧...
安卓6.0系统如何分区,And... 你有没有想过,你的安卓手机里那些神秘的分区到底是怎么来的?别急,今天就来给你揭秘安卓6.0系统如何分...
安卓系统图片怎么涂鸦,指尖上的... 你有没有想过,在安卓系统的手机上,那些单调的图片也能变得生动有趣呢?没错,就是涂鸦!今天,就让我来带...
安卓系统40g,40GB存储空... 你有没有发现,最近你的安卓手机突然变得有点“胖”了呢?没错,就是那个传说中的40G!别急,别慌,今天...
安卓5.0系统怎么重置,轻松实... 手机用久了是不是感觉卡得要命?别急,今天就来教你怎么给安卓5.0系统来个彻底的重置,让它焕发新生!一...
安卓系统是不是快要,安卓系统即... 你有没有发现,最近安卓系统好像有点儿“不安分”了呢?是不是快要发生什么大事情?咱们一起来探个究竟吧!...
安卓6系统和8系统差别,全面对... 你有没有发现,手机更新换代的速度简直就像坐上了火箭呢?这不,安卓系统也跟着时代的步伐,从6系统一路升...
安卓11系统推荐下载,体验全新... 你有没有发现,最近手机界又掀起了一股热潮?没错,就是安卓11系统!这款全新的操作系统一经推出,就吸引...
原生安卓系统怎样升级,从基础到... 你有没有发现,你的安卓手机用久了,有时候就像老牛拉车一样,慢吞吞的?别急,今天就来给你支个招,让你的...
安卓13系统怎么开发,开发者的... 你有没有听说安卓13系统已经发布了?这可是个大新闻呢!作为一个热衷于手机开发的小伙伴,你是不是也跃跃...
安卓q系统镜像下载,轻松升级体... 你有没有听说安卓Q系统已经发布了?这可是安卓家族里的一大亮点呢!今天,我就要来给你详细介绍一下安卓Q...
安卓系统色彩校正软件,打造个性... 你有没有发现,手机屏幕的色彩有时候会让人感觉不太对劲?有时候,画面看起来有点灰蒙蒙的,有时候又太艳丽...
苹果能否下个安卓系统,开启新篇... 你有没有想过,苹果的iOS系统会不会有一天突然宣布,它要拥抱安卓的大家庭呢?想象iPhone和iPa...