社区讨论

90分求助

题目总版参与者 2已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@m0du38t7
此快照首次捕获于
2024/08/28 20:30
2 年前
此快照最后确认于
2025/11/04 22:09
4 个月前
查看原帖
原题:P1125 90分代码如下。
CPP
#include <bits/stdc++.h>
using namespace std;
int prm(int tmp){
	if (tmp==0||tmp==1) return 0;
	for (int i=2;tmp%2!=0&&i*i<tmp;i%2==0?i++:i+=2)
		if (tmp%i==0) return 0;
	return 1;
}
int main(){
	string wd, md;
	int ans=0, minn=1000000, maxn=-100,tmp;
	bool sum[105]={};
	getline (cin,wd);
	for (int i=0;i<wd.size();i++){
		ans=1;
		if (sum[i]) continue;
		for (int j=i+1;j<wd.size();j++){
			if (wd[i]>'A')
			if (wd[i]==wd[j]&&wd[j]!=md[i]) {ans++;sum[j]=1;}
			maxn=max(maxn,ans);
			minn=min(minn,ans);
	 }
	}
	tmp=maxn-minn;
	if (prm(tmp)) cout << "Lucky Word"<< endl<< tmp;
	else cout << "No Answer"<< endl<< "0";
	return 0;
}
各位大佬谁能帮蒟蒻找找错误在哪(急迫)orz


**----------------------**

 **附原题及测试点**
测试点#2(未通过):
输入:
CPP
ubuntuubuntuubuntuubuntuubuntuu
输出:
CPP
Lucky Word
11

------------------------------------------------

题目描述

笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼。但是他找到了一种方法,经试验证明,用这种方法去选择选项的时候选对的几率非常大!
这种方法的具体描述如下:假设 \text{maxn}maxn 是单词中出现次数最多的字母的出现次数,\text{minn}minn 是单词中出现次数最少的字母的出现次数,如果 \text{maxn}-\text{minn}maxn−minn 是一个质数,那么笨小猴就认为这是个 Lucky Word,这样的单词很可能就是正确的答案。

输入格式

一个单词,其中只可能出现小写字母,并且长度小于 100。
输出格式 共两行,第一行是一个字符串,假设输入的的单词是 Lucky Word,那么输出 Lucky Word,否则输出 No Answer;
第二行是一个整数,如果输入单词是 Lucky Word,输出 maxn−minn 的值,否则输出 0。

回复

3 条回复,欢迎继续交流。

正在加载回复...