归纳编程学习的感悟,
记录奋斗路上的点滴,
希望能帮到一样刻苦的你!
如有不足欢迎指正!
共同学习交流!
🌎欢迎各位→点赞 👍+ 收藏⭐ + 留言📝
每一发奋努力的背后,必有加倍的赏赐!
一起加油!
题目描述
大头的词汇量很小,所以每次做英语选择题的时候都很头疼。但是他找到了一种方法,经试验证明,用这种方法去选择选项的时候选对的几率非常大!
这种方法的具体描述如下:假设 maxn
是单词中出现次数最多的字母的出现次数,minn
是单词中出现次数最少的字母的出现次数,如果 maxn-minn
是一个质数,那么大头就认为这是个 Lucky
,这样的单词很可能就是正确的答案。
输入格式
一个单词,其中只可能出现小写字母,并且长度小于 100
。
输出格式
共两行,第一行是一个字符串,假设输入的的单词是 Lucky
,那么输出“ Lucky”
,否则输出“ No Answer”
;
第二行是一个整数,如果输入单词是 Lucky
,输出 maxn-minn
的值,否则输出 0
。
输入输出样例
输入1
error
输出1
Lucky
2
单词
error
中出现最多的字母r
出现了3
次,出现次数最少的字母出现了1
次,3−1=2
,2
是质数。
输入2
olympic
输出2
No Answer
0
单词
olympic
中出现最多的字母ii出现了1
次,出现次数最少的字母出现了1
次,1−1=0
,0
不是质数。
代码附上:
#include<stdio.h>
#include<string.h>
void fun1(char *str,int n,int *max,int *min)
{
int i,j,k;
int pmax=0,pmin=100;
for(i=0;i<n;i++)
{
k=0;
for(j=i;j<n;j++)
{
if(str[i]==str[j])
{
k++;
}
}
if(k>pmax)
{
pmax=k;
}
if(k<pmin)
{
pmin=k;
}
}
*max=pmax;
*min=pmin;
}
int fun2(int n)
{
int flag=1;
if(n<2)
{
flag=0;
}
for(int i=2;i<n;i++)
{
if(n%i==0)
{
flag=0;
break;
}
}
return flag;
}
int main()
{
char str[100];
gets(str);
int n=strlen(str);
int max,min;
fun1(str,n,&max,&min);
int k=0;
k=fun2(max-min);
if(k==1)
{
printf("Lucky\n");
printf("%d",max-min);
}
else
{
printf("No Answer\n");
printf("0");
}
return 0;
}