原题链接:蓝桥杯算法提高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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复