首页 > 其他分享 >PAT Basic 1089. 狼人杀-简单版

PAT Basic 1089. 狼人杀-简单版

时间:2023-04-12 14:13:06浏览次数:60  
标签:PAT playerCount int 狼人 1089 玩家 ++ words

PAT Basic 1089. 狼人杀-简单版

1. 题目描述:

以下文字摘自《灵机一动·好玩的数学》:“狼人杀”游戏分为狼人、好人两大阵营。在一局“狼人杀”游戏中,1 号玩家说:“2 号是狼人”,2 号玩家说:“3 号是好人”,3 号玩家说:“4 号是狼人”,4 号玩家说:“5 号是好人”,5 号玩家说:“4 号是好人”。已知这 5 名玩家中有 2 人扮演狼人角色,有 2 人说的不是实话,有狼人撒谎但并不是所有狼人都在撒谎。扮演狼人角色的是哪两号玩家?

本题是这个问题的升级版:已知 \(N\) 名玩家中有 2 人扮演狼人角色,有 2 人说的不是实话,有狼人撒谎但并不是所有狼人都在撒谎。要求你找出扮演狼人角色的是哪几号玩家?

2. 输入格式:

输入在第一行中给出一个正整数 \(N\)(\(5≤N≤100\))。随后 \(N\) 行,第 \(i\) 行给出第 \(i\) 号玩家说的话(\(1≤i≤N\)),即一个玩家编号,用正号表示好人,负号表示狼人。

3. 输出格式:

如果有解,在一行中按递增顺序输出 2 个狼人的编号,其间以空格分隔,行首尾不得有多余空格。如果解不唯一,则输出最小序列解 —— 即对于两个序列 \(A=a[1],...,a[M]\) 和 \(B=b[1],...,b[M]\),若存在 \(0≤k<M\) 使得 \(a[i]=b[i]\) (\(i≤k\)),且 \(a[k+1]<b[k+1]\),则称序列 \(A\) 小于序列 \(B\)。若无解则输出 No Solution

4. 输入样例:

5
-2
+3
-4
+5
+4
6
+6
+3
+1
-5
-2
+4
5
-2
-3
-4
-5
-1

5. 输出样例:

1 4
1 5 (解不唯一)
No Solution

6. 性能要求:

Code Size Limit
16 KB
Time Limit
400 ms
Memory Limit
64 MB

思路:

一开始想着能找出规律,但这种智力题真做不明白。。。还是顺序遍历每种狼人的可能进行判断和输出,这样也能满足最小序列解的要求。编写子函数isSolution()进行逻辑判断,根据题目要求有且只有1个好人和1个狼人在撒谎。

My Code:

#include <stdio.h>

#define MAX_PLAYER (100+1)

int isSolution(const int *words, int playerCount, int wolf1, int wolf2);

int main(void)
{
    int playerCount = 0;
    int words[MAX_PLAYER] = {0};
    int i=0, j=0; // iterator
    //int wolfLieCount=0, goodLieCount=0;
    
    scanf("%d", &playerCount);
    //printf("%d\n", playerCount);
    
    for(i=1; i<=playerCount; ++i)
    {
        scanf("%d", &words[i]);
        //printf("%d\n", words[i]);
    }
    
    for(i=1; i<playerCount; ++i)
    {
        for(j=i+1; j<=playerCount; ++j)
        {
            if(isSolution(words, playerCount, i, j))
            {
                printf("%d %d\n", i, j);
                return 0;
                //break; // only exit one loop
            }
        }
    }
    
    if(i==playerCount) // no solution
    {
        printf("No Solution\n");
    }
    
    return 0;
}

int isSolution(const int *words, int playerCount, int wolf1, int wolf2) // 1 means is a solution, 0 means not.
{
    int wolfLieCount=0, goodLieCount=0;
    int i=1; // iterator
    
    for(i=1; i<=playerCount; ++i)
    {
        if(i==wolf1 || i==wolf2) // wolf talk
        {
            if(words[i]>0 && (words[i] == wolf1 || words[i] == wolf2)) // lie a wolf is good
            {
                ++wolfLieCount;
                //printf("wolf++: %d\n", i);
            }
            else if(words[i]<0 && (-words[i] != wolf1 && -words[i] != wolf2)) // lie a good is wolf
            {
                ++wolfLieCount;
                //printf("wolf++: %d\n", i);
            }
        }
        else // good talk
        {
            if(words[i]>0 && (words[i] == wolf1 || words[i] == wolf2)) // lie a wolf is good
            {
                ++goodLieCount;
                //printf("good++: %d\n", i);
            }
            else if(words[i]<0 && (-words[i] != wolf1 && -words[i] != wolf2)) // lie a good is wolf
            {
                ++goodLieCount;
                //printf("good++: %d\n", i);
            }
        }
    }
    
    //printf("wolfLie: %d, goodLie: %d\n", wolfLieCount, goodLieCount);
    
    if(wolfLieCount==1 && goodLieCount==1)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}

标签:PAT,playerCount,int,狼人,1089,玩家,++,words
From: https://www.cnblogs.com/tacticKing/p/17309597.html

相关文章

  • PAT Basic 1088. 三人行
    PATBasic1088.三人行1.题目描述:子曰:“三人行,必有我师焉。择其善者而从之,其不善者而改之。”本题给定甲、乙、丙三个人的能力值关系为:甲的能力值确定是2位正整数;把甲的能力值的2个数字调换位置就是乙的能力值;甲乙两人能力差是丙的能力值的X倍;乙的能力值是丙的Y倍。......
  • xpath数据解析
    xpath解析xpath是一种在XML文档中査找信息的语言,可用来在XML文档中対元素和属性进行遍万。HTML属于XML的一个子集。1、导入fromlxmlimportetree#如果导入报错,则使用以下方式fromlxmlimporthtmletree=html.etree2、创建xpath对象#解析XML文件et=etree.XML......
  • PAT Basic 1087. 有多少不同的值
    PATBasic1087.有多少不同的值1.题目描述:当自然数 \(n\) 依次取\(1、2、3、……、N\) 时,算式 \(⌊n/2⌋+⌊n/3⌋+⌊n/5⌋\) 有多少个不同的值?(注:\(⌊x⌋\) 为取整函数,表示不超过 \(x\) 的最大自然数,即 \(x\) 的整数部分。)2.输入格式:输入给出一个正整数 \(N\)(\(......
  • PAT Basic 1086. 就不告诉你
    PATBasic1086.就不告诉你1.题目描述:做作业的时候,邻座的小盆友问你:“五乘以七等于多少?”你应该不失礼貌地围笑着告诉他:“五十三。”本题就要求你,对任何一对给定的正整数,倒着输出它们的乘积。2.输入格式:输入在第一行给出两个不超过1000的正整数A和B,其间以空格分隔。......
  • pytest中的monkeypatch
    一、猴子补丁简介在有些场景下的测试可能需要修改全局配置或者系统变量等操作,而这些操作仅仅是为了做一些测试,不希望永久的修改,此时就需要使用猴子补丁了,猴子补丁,即monkeypatch,是一个fixture,它提供了以下方法:monkeypatch.setattr(obj,name,value,raising=True)monkeypatch.se......
  • PAT Basic 1085. PAT单位排行
    PATBasic1085.PAT单位排行1.题目描述:每次PAT考试结束后,考试中心都会发布一个考生单位排行榜。本题就请你实现这个功能。2.输入格式:输入第一行给出一个正整数N(\(≤10^5\)),即考生人数。随后N行,每行按下列格式给出一个考生的信息:准考证号得分学校其中准考证号是由......
  • chromium 的 diff, patcher
    1,编译出来:autoninja-Cout\Defaultcourgette2,使用e:\\chromium\src\out\Default>courgette64.exeFirstargumentmustbeoneof: -supported,-asm,-dis,-disadj,-gen,-apply,-genbsdiff,-applybsdiff,or-gen1[au].MainUsage: courgette-gen<......
  • ida patch
    安装keypatch在GitHub安装下载Keypatch.py复制到插件目录IDA7.0\plugins\Keypatch.py下载安装keystonepython模块,通过pipinstallkeystone-engine或者,64位系统只需要安装https://github.com/keystone-engine/keystone/releases/download/0.9.1/keystone-0.9.1-python-w......
  • (KMP 1.1)hdu 1711 Number Sequence(KMP的简单应用——求pattern在text中第一次出现的
    题目:NumberSequenceTimeLimit:10000/5000MS(Java/Others)    MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):12902    AcceptedSubmission(s):5845ProblemDescriptionGiventwosequencesofnumbers:a[1],a[2],......,a[N],andb[1......
  • PAT Basic 1082. 射击比赛
    PATBasic1082.射击比赛1.题目描述:本题目给出的射击比赛的规则非常简单,谁打的弹洞距离靶心最近,谁就是冠军;谁差得最远,谁就是菜鸟。本题给出一系列弹洞的平面坐标(x,y),请你编写程序找出冠军和菜鸟。我们假设靶心在原点(0,0)。2.输入格式:输入在第一行中给出一个正整数N(≤10......