前言
正文
参考题解
#include<iostream>
#include<algorithm>
using namespace std;
/* 题意:狼人杀,n个玩家,其中有两个狼人,有一个狼人说谎,有一个人类说谎,求狼人的编号 思路:双重循环遍历所有玩家,假设当年某两个玩家是狼人,则他们之中必有一个人说真话而 另外一个人是说假话。可根据人类是正数,狼人是负数来设计说谎的判断条件 */
const int N=110;
int n;
int v[N];
bool isSolution(int &i,int &j){
for(i=1;i<=n;i++){
for(j=i+1;j<=n;j++){//假设i,j号为狼人
int wolfs=0,lies=0;//lies表示说谎的人数,wolfs表示狼人说谎的人数 ,则当lies==2&&wolfs==1时,则假设成功
for(int k=1;k<=n;k++){
if(v[k]==i||v[k]==j||(v[k]<0&&v[k]!=-i&&v[k]!=-j)){ //狼人说谎时或者人类说谎时
lies++;
if(k==i||k==j)wolfs++; //狼人说谎
}
}
if(lies==2&&wolfs==1)return true;
}
}
return false;
}
int main(){
cin>>n;
int temp;
for(int i=1;i<=n;i++){
cin>>v[i];
}
int i,j;
if(isSolution(i,j))printf("%d %d\n",i,j);
else printf("No Solution\n");
return 0;
}