原题链接:蓝桥杯算法提高VIP-笨小猴
wa了好多次,错的原因就这一点,素数判断时没判特殊情况,超时的原因就因为用getchar导致的,改成scanf就没问题了,以下附AC代码。
参考代码:
#include <stdio.h> #include <math.h> int fun(int n){ //质数判断 int i; for(i = 2; i <= sqrt(n); i++){ if(n%i == 0) return 0; } return ((n<=1)?(0):(1)); //处理特殊情况,即n为0或1时 } int main(){ char s[100]; //单词 int flag[123] = {0}; //单词中每个字母所出现的次数 int maxn = 0,minn = 99; //单词中出现次数最多的字母的出现次数,以及单词中出现次数最少的字母的出现次数 int i; scanf("%s", s); for(i = 0; s[i] != '\0'; i++){ //统计每个字母出现的次数 flag[s[i]]++; } for(i = 97; i <= 122; i++){ //找单词中出现次数最多的字母的出现次数,以及单词中出现次数最少的字母的出现次数 if(flag[i] > 0){ if(maxn < flag[i]){ maxn = flag[i]; } if(minn > flag[i]){ minn = flag[i]; } } } if(fun(maxn-minn) == 1){ //是质数 printf("Lucky Word\n%d", maxn-minn); } else{ //不是质数 printf("No Answer\n0"); } return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复