某班中的一位同学做了好事不留名,表扬信来了之后,班主任问A,B,C,D,E,F 六位同学是谁做的好事,六位的回答如下:
A说:不是我。
B说:是C。
C说:是D。
D说:C胡说。
E说:不是C就是E
F说:即不是D也不是E
如果N个人说的是真话,则根据这些信息,找出可能做了好事的人。
输入格式:
输入N,N个人可能说的是真话
输出格式:
有可能做好事的同学(A-F),如果有多位同学有可能做好事,则同学名称按字典序全部输出。同学名之间用" or “间隔。 如果无法找出,输出"Error”。
输入样例:
2
输出样例:
在这里给出相应的输出。例如:
A or D
知识点
思路:
flag 来确定第一个没有or 第二个有or …
用sum来记录有几个人说对了,和n比较
代码
#include<iostream>
using namespace std;
int main(){
int n;cin>>n;
int flag=0;
for(int i=0;i<6;i++){
char thisman=(char)(65+i);
int sum=0;
if(thisman!='A')sum++;
if(thisman=='C')sum++;
if(thisman=='D')sum++;
if(thisman!='D')sum++;
if(thisman=='C'||thisman=='E')sum++;
if(thisman!='D'&&thisman!='E')sum++;
if(sum==n){
if(flag==0)cout<<thisman;
else cout<<" or "<<thisman;
flag=1;
}
}
if(flag==0)cout<<"Error";
}
最后
以上就是追寻蜗牛最近收集整理的关于7-38 逻辑判断-谁做了好事! (10分)的全部内容,更多相关7-38内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复