小于哥的鱼干


私信TA

用户名:yuhui1207

访问量:18179

签 名:

在人间已是巅,何苦要上青天

等  级
排  名 414
经  验 5013
参赛次数 2
文章发表 32
年  龄 24
在职情况 在职
学  校 常熟理工
专  业

  自我简介:

解题思路:
    1.字符串操作

    2.做一个字母到整数的映射,小写字母'a' 减去'a'为0,'b'减去'a'为1,刚好对应存放26个字母的数组下标

    3.声明一个26个元素的整型数组,统计字母个数,遍历该数组,找出最大值,最小值

    4.判断两者之差是否为素数,然后按要求打印

注意事项:
    细心一点,有时候一个大于写成小于,也会让你头疼不已
参考代码:

#include <stdio.h>
#include <string.h>
int main()
{
	char s[100];
	int i,len,a[26]={0};
	int min,max,t;
	scanf("%s",s);
	len=strlen(s);
	for(i=0;i<len;i++)
	{
	    a[s[i]-'a']++;        //字母到整数的映射
	}
	max=0;
	min=99;
	for(i=0;i<26;i++)
	{
		if(a[i])            //这里很重要,因为我们只统计出现过的字母
		{
			if(max<a[i])            //找出最大值最小值
				max=a[i];
			if(min>a[i])
				min=a[i];
		}
	}
	t=max-min;
	if(t<2)
		printf("No Answer\n0");
	if(t==2)
		printf("Lucky Word\n%d",t);
	if(t>2)
	{
		for(i=2;i<t;i++)
		{
			if(t%i==0)
				break;        //判断是否为素数
		}
		if(i<t)
			printf("No Answer\n0");
		else
			printf("Lucky Word\n%d",t);
	}
	return 0;
}


 

0.0分

16 人评分

  评论区

佩服,厉害,666,膜拜大佬
2021-08-17 16:09:52
  • «
  • 1
  • »