ZOJ 3960 What Kind of Friends Are You? 【状态标记】
题目链接
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3960
题意
首先给出 一系列名字 需要辨别的名字,然后给出Q个问题,每个问题有 若干个人给出答案,给出答案的人 此时状态 为1 没有给出答案 的 状态为0 
最后给出 三个需要辨识的状态,如果有且只有一个人 跟这个状态相同 就输出这个人的名字
AC代码
#include <cstdio>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <map>
#include <stack>
#include <set>
#include <numeric>
#include <sstream>
using namespace std;
typedef long long LL;
const double PI = 3.14159265358979323846264338327;
const double E = 2.718281828459;
const double eps = 1e-6;
const int MAXN = 0x3f3f3f3f;
const int MINN = 0xc0c0c0c0;
const int maxn = 1e5 + 5;
const int MOD = 1e9 + 7;
int main()
{
    int t;
    scanf("%d", &t);
    while (t--)
    {
        int n, q;
        int i, j;
        scanf("%d%d", &n, &q);
        map <string, string> M;
        M.clear();
        string s, temp = "";
        for (i = 0; i < q; i++)
            temp += "0";
        int m;
        scanf("%d", &m);
        for (i = 0; i < m; i++)
        {
            cin >> s;
            M[s] = temp;
        }
        for (i = 0; i < q; i++)
        {
            scanf("%d", &m);
            for (j = 0; j < m; j++)
            {
                cin >> s;
                M[s][i] = '1';
            }
        }
//      map <string, string>::iterator it;
//      for (it = M.begin(); it != M.end(); it++)
//          cout << it -> first << " " << it -> second << endl;
        string ans;
        int num;
        for (i = 0; i < n; i++)
        {
            temp.clear();
            for (j = 0; j < q; j++)
            {
                scanf(" %d", &num);
                temp += num + '0';
            }
            int flag = 0;
            ans.clear();
            map <string, string>:: iterator it;
            for (it = M.begin(); it != M.end(); it++)
            {
                if (it -> second == temp )
                {
                    if (flag == 1)
                    {
                        flag = 0;
                        break;
                    }
                    else
                    {
                        flag = 1;
                        ans = it -> first;
                    }
                }
            }
            if (flag)
                cout << ans << endl;
            else
                printf("Let's go to the library!!\n");
        }
    }
}
ZOJ 3960 What Kind of Friends Are You? 【状态标记】的更多相关文章
- 2017浙江省赛 C - What Kind of Friends Are You? ZOJ - 3960
		地址:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3960 题目: Japari Park is a large zoo ... 
- What Kind of Friends Are You?  ZOJ 3960
		比赛的时候用vector交集做的...情况考虑的不全面 wrong到疯 赛后考虑全了情况....T了 果然 set_intersection 不能相信 嗯 不好意思 交集a了 第二个代码 求出来 ... 
- ZOJ 3960 What Kind of Friends Are You?(读题+思维)
		题目链接 :http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5592 Japari Park is a large zoo hom ... 
- What Kind of Friends Are You? ZOJ - 3960(ZheJiang Province Contest)
		怎么说呢...我能说我又过了一道水题? emm... 问题描述: 给定 n 个待确定名字的 Friends 和 q 个问题.已知 c 个 Friends 的名字. 对于第 i 个问题,有 个 Fri ... 
- zoj 3960 What Kind of Friends Are You?(哈希)
		What Kind of Friends Are You? Time Limit: 1 Second Memory Limit: 65536 KB Japari Park is a larg ... 
- ZOJ 3960:What Kind of Friends Are You?
		What Kind of Friends Are You? Time Limit: 1 Second Memory Limit: 65536 KB Japari Park is a large zoo ... 
- HDU 1400 (POJ 2411 ZOJ 1100)Mondriaan's Dream(DP + 状态压缩)
		Mondriaan's Dream Problem Description Squares and rectangles fascinated the famous Dutch painter Pie ... 
- ZOJ - 3954  Seven-Segment Display 【状态标记】
		题目链接 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3954 题意 有一块 LED 灯 然后上面有七块灯管 在显示不同数 ... 
- poj 1080 zoj 1027(最长公共子序列变种)
		http://poj.org/problem?id=1080 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=27 /* zoj ... 
随机推荐
- c++ 请抛弃匈牙利命名法 - 变量命名代码风格的建议。
			我只针对c++码农们讲,其他语言不了解不过应该大同小异.曾几何时翻开21天学通c++系列等脑残入门书,都以匈牙利命名法示人(DWORD dwXXX, int nXXX, string strXXX). ... 
- EEPlat的元模型体系
			EEPlat的元模型体系是元数据驱动的必要条件之中的一个.仅仅有通过元模型可以完好的描写叙述一个软件系统.才可以完整的定义该软件系统的元数据,也才干真正实现软件系统的元数据驱动式开发.也就意味着一个软 ... 
- jquery - 动态绑定事件
			举个例子: html页面 <div><button type="button" class="test">测试</button&g ... 
- eclipse通过maven远程发布应用到Tomcat
			好久没有写博客了,今天为大家分享一下如何在eclipse通过maven远程发布应用到Tomcat. 一般情况下,我们发布应用到服务器需要现将应用导出成war包,然后连接服务器部署更新,这样是很耗时的, ... 
- VMware-vSphere-5.1--------群集、HA、DRS、FT
			VMware vSphere 5.1 高可用性 在本节中主要讲的是集群的一些功能和配置,相比5.0的设置,没有太大的变化.VMware vSphere为虚拟机提供虚拟化的基础架构,将现有的 ... 
- Servlet 环境设置
			开发环境是您可以开发.测试.运行 Servlet 的地方. 就像任何其他的 Java 程序,您需要通过使用 Java 编译器 javac 编译 Servlet,在编译 Servlet 应用程序后,将它 ... 
- 2017 css新特性
			2017年要学习的三个CSS新特性 这是翻译的一篇文章,原文是:3 New CSS Features to Learn in 2017,翻译的不是很好,如有疑问欢迎指出. 新的一年,我们有一系列新的东 ... 
- 使用json遇到的问题
			JSON JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式.它基于 ECMAScript (w3c制定的js规范)的一个子集,采用完全独立 ... 
- R-ArcGIS探秘(1)安装以及Sample执行
			在今年的全球用户大会上,Esri官方发布了R-ArcGIS的官方演示样例,在ArcMap和ArcGIS pro中,直接通过Toolbox能够调用R的分析工具包,将R的分析能力直接作用在ArcGIS上面 ... 
- Android无线测试之—UiAutomator UiDevice API介绍四
			拖拽与滑动 一.概念介绍: 1)拖拽:将组建从一个坐标移动到另一个坐标 2)移动:从一二坐标点移动到另一个坐标点 3)步长:从一点滑动到另一点使用的时间 二.拖拽与滑动的相关API: 返回值 方法名 ... 
