洛谷 P1039 侦探推理
题目:https://www.luogu.org/problemnew/show/P1039
分析:
这道题是一道有技术含量的模拟,我们主要是不要让计算机向人一样思考,只需要让他穷举变化的星期几和当罪犯的人的编号即可,然后就是用string来操作会显得十分方便
#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
using namespace std;
int n,m,p,fake[21],err,w[200],nx;
string name[100],say[200];
string day[10]={"QAQ","Today is Sunday.","Today is Monday.","Today is Tuesday.","Today is Wednesday.","Today is Thursday.","Today is Friday.","Today is Saturday."};
void set(int who,int yx)
{
    if(fake[who]&&fake[who]!=yx)err=1;
    else fake[who]=yx;
}
int main()
{
    scanf("%d%d%d",&m,&n,&p);
    for(int i=1;i<=m;i++)
        cin>>name[i];
    for(int i=1;i<=p;i++)
	{
        string nm;
        cin>>nm;
        nm.erase(nm.end()-1);
        for(int j=1;j<=m;j++)
        	if(name[j]==nm)
				w[i]=j;
        getline(cin,say[i]);
        say[i].erase(say[i].begin());
        say[i].erase(say[i].end()-1);
    }
    for(int td=1;td<=7;td++)
    for(int px=1;px<=m;px++)
	{
        err=0;
        memset(fake,0,sizeof(fake));
        for(int i=1;i<=p;i++)
		{
            int who=w[i];
            if(say[i]=="I am guilty.")set(who,px==who?1:-1);
            if(say[i]=="I am not guilty.")set(who,px!=who?1:-1);
            for(int j=1;j<=7;j++)
            if(say[i]==day[j])set(who,j==td?1:-1);
            for(int j=1;j<=m;j++)
			{
                if(say[i]==name[j]+" is guilty.")set(who,j==px?1:-1);
                if(say[i]==name[j]+" is not guilty.")set(who,j!=px?1:-1);
            }
        }
        int cnt=0,ppp=0;
        for(int i=1;i<=m;i++)
		{
            if(fake[i]==-1)cnt++;
            if(fake[i]==0)ppp++;
        }
        if(!err&&cnt<=n&&cnt+ppp>=n)
            if(nx&&nx!=px)
			{
                printf("Cannot Determine");
                return 0;
            }
			else nx=px;
    }
    if(!nx)printf("Impossible");
    else cout<<name[nx];
    return 0;
}
完结撒花~
洛谷 P1039 侦探推理的更多相关文章
- 洛谷P1039 侦探推理(模拟)
		
侦探推理 题目描述 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先商量好由其中的一个人充当罪犯(在明明不知情的情 ...
 - 洛谷 P1039侦探推理
		
/* 枚举罪犯和星期几,那么所有人说的话是真是假一目了然. 首先一个人不能既说真话又说假话. 即: I am guilty. I am not guilty. 因为非真即假,所以直接判断impossi ...
 - [NOIP2003] 提高组 洛谷P1039 侦探推理
		
题目描述 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先商量好由其中的一个人充当罪犯(在明明不知情的情况下),明 ...
 - 洛谷P1039侦探推理题解
		
#include<cstdio> #include<cstring> #include<string> #include<iostream> using ...
 - Luogu P1039 侦探推理(模拟+枚举)
		
P1039 侦探推理 题意 题目描述 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先商量好由其中的一个人充当罪犯 ...
 - 【洛谷P1039】侦探推理
		
侦探推理 题目链接 这是一道恶心至极的模拟题 我们可以枚举罪犯是谁,今天是星期几,从而判断每个人说的话是真是假 若每个人说的话的真假一致,且说谎话的人数<=k且说真话的人数<=m-k,就是 ...
 - P1039 侦探推理(洛谷)
		
昨天做了一个非常神奇的题,告诉我们做题之前一定要好好检测评测姬! 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先 ...
 - P1039 侦探推理
		
题目描述 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先商量好由其中的一个人充当罪犯(在明明不知情的情况下),明 ...
 - LUOGU P1039 侦探推理 (字符串+模拟)
		
传送门 解题思路 一道%你神题,\(string\)好强大啊..首先枚举一个周几,再枚举一个罪犯是谁,然后判断的时候就是枚举所有人说的话.定义\(fAKe[i]\)表示第\(i\)个人说的是真话还是假 ...
 
随机推荐
- 关于jquery.fileupload结合PHP上传图片的开发用法流程
			
这阵子做了一个项目,涉及到了图片上传,以往用的都是uploadify这个插件,感觉它在PC上的使用还是很强大的, 不过最近这个项目涉及到了移动端的上传,其实uploadify也可以,但是他有一个 up ...
 - C#图片灰度处理(位深度24→位深度8),用灰度数组byte[]新建一个8位灰度图像Bitmap 。
			
原文:C#图片灰度处理(位深度24→位深度8) #region 灰度处理 /// <summary> /// 将源图像灰度化,并转化为8位灰度图像. /// </summary> ...
 - QT_NO_CAST_FROM_ASCII这个宏的,禁用一切来自双引号字符串字面量传入QString(有2种解决方法)
			
这两天制作了两个Qt Creator增强套装的两个插件,其实也是非常简单的,但是其实花了我超过四天的时间,为什么呢?因为我之前很长一段时间都是在Linux下开发的,一切安好,没有任何问题,但是到了Wi ...
 - Windows系统版本判定那些事儿(有图,各种情况,很清楚)
			
前言 本文并不是讨论Windows操作系统的版本来历和特点,也不是讨论为什么没有Win9,而是从程序员角度讨论下Windows获取系统版本的方法和遇到的一些问题.在Win8和Win10出来之后,在获取 ...
 - 虚拟化代码博客 good
			
推荐网站和博客地址 -------------------------------- 虚拟化代码博客 QEMU大牛博客:qemu - 韋任的維基百科 http://people.cs.nctu ...
 - Qt浅谈之二十七进程间通信之QtDBus good
			
一.简介 DBus的出现,使得Linux进程间通信更加便捷,不仅可以和用户空间应用程序进行通信,而且还可以和内核的程序进行通信,DBus使得Linux变得更加智能,更加具有交互性. DB ...
 - python合并多个文件
			
import os filelist=os.listdir('/root/Music') for item in filelist: print item newfile=open('/root/Mu ...
 - 零基础配置Hadoop集群——Ambari安装及配置详解
			
1. 准备工作 1.1. 系统环境 主机列表: IP地址 HostName 描述 192.168.610.153 ambari.server Ambari服务器 192.168.10.152 had ...
 - Hive 学习之路(三)——  Hive CLI和Beeline命令行的基本使用
			
一.Hive CLI 1.1 Help 使用hive -H或者 hive --help命令可以查看所有命令的帮助,显示如下: usage: hive -d,--define <key=value ...
 - C#使用 SSL Socket 建立 Client 与 Server 连接
			
当 Client 与 Server 需要建立一个沟通的管道时可以使用 Socket 的方式建立一个信道,但是使用单纯的 Socket 联机信道可能会担心传输数据的过程中可能被截取修改因而不够安全,为了 ...