当前位置: 首页 > 编程日记 > 正文

PAT(甲级)2018年秋季考试 7-1 Werewolf - Simple Version

1. 我设置了一个结构体变量存储每个人的指控信息

struct IF{int type = 0;int no;
};

这里我发现了一件事,如果结构体只有有参数的构造函数,那么直接声明该结构体类型的数组是不行的。但是好处是数组知道下标可以直接赋值。

也就是这样组合最好:

不带有参构造函数的结构体+结构体类型数组

带+结构体类型向量

其次我在判断type类型时,根据读到的符号是不是'-'来判断,但是忘记了吸收空格,所以读到的全部都是空格,后面的no出现了不希望看到的负值,这是调试过程中才发现。

2. 整体思路是,已知有1个平民和1个狼人撒谎,那么进行双循环,共n(n-1)中可能,对于每种可能,在内部走一遍游戏的流程,如果出现冲突,也就是一个人既被判断成狼人,又被判断成平民,说明这种可能不成立,此外,还根据狼人数目。值得注意的是,不是每个人都会被判断出结果,也就是狼人数目为1时,当前情况依然可能成立。

以下是我判断出成立的条件

if(cl&&(wolfnum==2||mannum==n-2)&&(hash[i]!=1||hash[j]!=1))

2.1. 不能产生冲突

2.2. 狼人数量为2,或平民数量为总人数-2

2.3. 两个说谎的人中至少有一个是狼人

很遗憾,最后测试用例都通过的情况下,提交结果发现还是2分。

3. 于是转变思路,不再把前置条件设成哪两个人说谎,而是设成哪两个人是狼人,这样做首先就有一个好处是,首先得到结果一定是最小的序列,不需要再往下。

而且检测是否成立的方式是记录说慌的狼和人的总数,说谎的狼人的总数,一趟下来,看前者==2+后者==1是否都成立。如果是,直接按顺序输出外层和内层循环号,返回0。

AC代码

#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<queue>
#include<string>
#include<map>
#include<vector>
#include<set>using namespace std;const int maxn = 110;struct IF{int type = 0;int no;
};IF info[maxn];int main(){int n;scanf("%d",&n);int type,no;char c;for(int i=1;i<=n;i++){getchar();scanf("%c%d",&c,&no);if(c=='-')type = -1;else type = 1;info[i].no = no;info[i].type = type;}for(int i=1;i<n;i++){for(int j=i+1;j<=n;j++){int liarN = 0;//撒谎的人和狼的总数量int liarwolfN = 0;//撒谎的狼人的数量//i和j是狼人 for(int k=1;k<=n;k++){//走一遍流程,看是否出现冲突 if(info[k].no==i||info[k].no==j){if(info[k].type==1){liarN ++;if(k==i||k==j)liarwolfN ++;}	}else{if(info[k].type==-1){liarN ++;if(k==i||k==j)liarwolfN ++;}} }if(liarN==2&&liarwolfN==1){printf("%d %d",i,j);return 0;}}}printf("No Solution\n");return 0;
}

又做了一次,这次改成了判断撒谎的狼人数==1和撒谎的平民数==1是否同时成立。代码更简洁了

#include<iostream>
#include<cstdio>
#include<cmath>
#include<vector>
#include<map>
#include<algorithm>using namespace std;const int maxn = 110;int n,A[maxn];vector<pair<int,int> > ans; bool cmp(pair<int,int> a,pair<int,int> b){return a.first!=b.first?a.first<b.first:a.second<b.second;
}int main(){cin>>n;for(int i=1;i<=n;i++){cin>>A[i];}for(int i=1;i<n;i++){for(int j=i+1;j<=n;j++){int lieWolf = 0;int lieMan = 0;for(int k=1;k<=n;k++){if(A[k]<0&&-A[k]!=i&&-A[k]!=j){if(k==i||k==j)lieWolf ++;else lieMan ++;}if(A[k]>0&&(A[k]==i||A[k]==j)){if(k==i||k==j)lieWolf ++;else lieMan ++;}}if(lieWolf==1&&lieMan==1)ans.push_back(make_pair(i,j));}}//	cout<<ans.size()<<endl;if(ans.size()==0){printf("No Solution\n");return 0;}else if(ans.size()==1){printf("%d %d\n",ans[0].first,ans[0].second);return 0;}else{sort(ans.begin(),ans.end(),cmp);printf("%d %d\n",ans[0].first,ans[0].second);}return 0;
}

相关文章:

appium 启动失败解决方案

本机下载了&#xff1a;AppiumForWindows&#xff0c;启动Appium.exe 的时候&#xff0c;立即提示&#xff1a;应用程序已停止运行&#xff01;&#xff01; 本机环境&#xff1a; WIN 7 64 位&#xff0c;后来查了资料才知道Appium 要求安装.net framework 4.5&#xff0c;本机…

Django基础-数据分页

2019独角兽企业重金招聘Python工程师标准>>> pager.py # -*- coding:utf8 -*- """ 引用说明&#xff1a; 数据总个数&#xff1a;total_count 数据总页数&#xff1a;num_pages 每页显示的行数&#xff1a;perPageItemNum【默认显示10行】 最多显示页…

存货的计划属性设置(ATO模型和PTO模型)

对于原来应用ERP1时已经存在的存货&#xff0c;如果在存货属性中没有进行过设置或者设置不完善&#xff0c;需要进行补充设置。这样的补充设置包括&#xff1a; 自制&#xff1a;具有该属性的存货可由企业生产自制。如工业企业生产的产成品、半成品等存货。具有该属性的存货可用…

(C++)判断一个序列是non-increasing/non-decreasing还是两者都不的两个方法

思路&#xff1a;根据前两个值预设类型&#xff0c;再遍历后面的pair&#xff0c;看是否推翻预设 int judgeType(vector<int> vi){//-1 递减 0 啥也不是 1 递增 if(vi.size()1)return 0;//根据前两个元素的大小设置初始类型int type;if(vi[1]>vi[0])type 1;else …

java 下载文件功能代码例子

public static void down(HttpServletRequest request, HttpServletResponse response) throws Exception { String name"aaa.*";//文件名 String uploadPath UploadFileHelper.getRepositoryPath()"//";//文件来源 String filePath…

不要小看字符串

字符串非常非常常见又重要&#xff0c;而且还有那么多名堂在里面 字符串: 在标准C中&#xff0c;是没有字符串变量的&#xff0c;但是有字符数组。而且标准C带有的标准库函数&#xff1a;string.h中包含了大量的字符串操作函数&#xff0c;当然如果必要的话&#xff0c;你也可以…

零基础学习Python需要注意的几个点,Python培训机构排名

俗话说的好万事开头难&#xff0c;不管你做任何事情&#xff0c;开头的确很较难的&#xff0c;学Python编程也是如此&#xff0c;因此刚开始学Python编程的同学们&#xff0c;就要多借鉴过来人的经验&#xff0c;少走弯路&#xff0c;本文小编就为大家分享几个Python编程小白初…

PAT(甲级)2018年冬季考试 7-4 Heap Paths(非递归与递归解法)

非递归解法 1. 前置知识&#xff1a;完全二叉树的属性 1.1 从1开始存储&#xff0c;子节点的下标除以二得到的是父节点的下标 1.2 数组的存放顺序刚好是层序遍历顺序 1.3 从1开始存储&#xff0c;节点的下标i和结点总数n如果满足 i*2>n说明该结点是叶子结点 2. 思路&am…

Request Connection: Remote Server @ 192.229.145.200:80

录制Loadrunner脚本时&#xff0c;提示&#xff1a;Request Connection: Remote Server 192.229.145.200:80 NOT INTERCEPTED!(REASON: User requested to IGNORE connection)&#xff1b;解决方法&#xff1a;1. 打开IE里的Internet选项&#xff0c;单击连接选项卡。单击最…

抽象工厂与工厂模式例子

NativeFactory。java package com;//定义 人有杀日本人 和 杀美国人两个方法interface NativePerson{ public void killAmeria(); public void killJapan();}//中国人实现了人的接口 class NativeChinese implements NativePerson{ //中国人杀美国人 public void killAmeria() …

《疯狂Java讲义》学习笔记(十)异常处理

2019独角兽企业重金招聘Python工程师标准>>> 0、Java的异常体系 1、异常概述 异常机制已经成为判断一门编程语言是否成熟的标准&#xff0c;目前主流的编程语言都提供了成熟的异常机制&#xff0c;增加了异常处理机制后的程序有更好的容错性&#xff0c;更加健壮 Ja…

PAT(甲级)2018年冬季考试 7-1 Google Recruitment

1. 本题是 substrsscanf的绝佳实践。 2. 判断素数使用i*i<n与i<(int)sqrt(0.1*x)的区别是前者可能再n接近10的9次方时溢出&#xff0c;但本题不会。 3. 尽管把字符串转变成了整数&#xff0c;但输出时仍旧输出字符串&#xff0c;如果选择打印整数&#xff0c;会遇到%0K…

MySQL 的“root”用户修改密码

MySQL 的“root”用户默认状态是没有密码的&#xff0c;所以在 PHP 中您可以使用 mysql_connect("localhost","root","") 来连接 MySQL 服务器&#xff1b;如果您想为 MySQL 中的“root”用户设置密码&#xff0c;请在控制台中使用“mysqladmin”…

游戏AI之初步介绍(0)

目录 游戏AI是什么&#xff1f;游戏AI和理论AI智能的假象&#xff08;更新&#xff09;游戏AI和机器学习介绍一些游戏AI4X游戏AI《求生之路》系列角色扮演/沙盒游戏中的NPC游戏AI 需要学些什么&#xff1f;自治智能体群体智能感知状态机&#xff08;重要&#xff09;行为树&…

Google Adsense实用防踢技巧总结

我们都知道&#xff0c;对个人草根站长来说&#xff0c;Google AdSense是网站收入的主要来源之一&#xff0c;我在这里介绍一些常用的技巧。 希望通过这些技巧能够增加大家的Google AdSense收入&#xff0c;并防止自己的帐号被删除。大家喜欢的话就顶下吧&#xff01; 广告的位…

PAT(甲级)2018年冬季考试 7-3 Vertex Coloring

1. 起先我的思路是&#xff0c;对于每一种方案&#xff0c;把相同颜色的下标放到一个集合&#xff0c;对于每一个集合判断里面的元素互相之间是否有着邻接关系。有一个用例超时&#xff0c;20/25。 2. 转变思路&#xff0c;对于每一种方案&#xff0c;遍历邻接关系&#xff0c…

蚂蚁金服×西安银行 | 西安银行手机银行App的智能升级之路

小蚂蚁说&#xff1a;当前&#xff0c;数字化信号已经逐渐深入到社会的每个角落&#xff0c;影响着用户的心智和行为&#xff0c;来到数字化时代门口的银行&#xff0c;需要注意到数字化信号。西安银行通过引入蚂蚁金服移动开发平台mPaaS&#xff0c;对手机银行进行架构升级&am…

(四十七)Quartz2D引擎初步

Quartz2D是跨平台的&#xff0c;同时支持iOS与Mac。 支持圆型裁剪&#xff0c;可以实现圆形头像等功能&#xff0c;也支持手势解锁、折线图等的制作。 对于复杂的UI界面&#xff0c;还可以通过Quartz2D将控件内部的结构画出来&#xff0c;可用于自定义控件。 实际上iOS大部分控…

PAT(甲级)2018年冬季考试 7-2 Decode Registration Card of PAT

目录 体会 代码(非满分) 改进 AC代码 体会 这题主要是考察对STL中string,map,vector的应用以及自定义sort()应用。 类型1和2的处理很容易。 类型3要求对于指定date&#xff0c;按照每个考场进行分类&#xff0c;记录不同考场的人数&#xff0c;按照人数非升序&#xff…

DOS、Mac 和 Unix 文件格式+ UltraEdit使用

文件格式 区分DOS、Mac 和 Unix分别对应三种系统从文件编码的方式来看&#xff0c;文件可分为ASCII码文件和二进制码文件两种文件模式 区分ASCII模式和Binary模式 通常由系统决定&#xff0c;大多数Linux/UNIX系统只有两种模式&#xff1a;文本模式和二进制模式。文本传输器使用…

灰度图像--图像分割 Scharr算子

学习DIP第46天 转载请标明本文出处&#xff1a;http://blog.csdn.net/tonyshengtan &#xff0c;出于尊重文章作者的劳动&#xff0c;转载请标明出处&#xff01;文章代码已托管&#xff0c;欢迎共同开发&#xff1a; https://github.com/Tony-Tan/DIPpro 更多图像处理机器学习…

FileUpload生成图片水印,文字水印(转载)

/** <summary>/// 生成缩略图/// </summary>/// <param name"originalImagePath">源图路径&#xff08;物理路径&#xff09;</param>/// <param name"thumbnailPath">缩略图路径&#xff08;物理路径&#xff09;</para…

1151 LCA in a Binary Tree (含求LCA的通法)

目录 解法一思路 结果 解法一改进 解法一改进结果 ​解法二思路 解法一代码 解法一改进代码 解法二代码(AC) 解法一思路 1. 根据先序和中序建树 2. 对树进行深度优先遍历&#xff0c;找到每一个结点的父节点(注意&#xff1a;由于值的范围是int&#xff0c;直接用可…

cf 414B Mashmokh and ACM 动态规划

题目链接&#xff1a;http://codeforces.com/problemset/problem/414/B dp[i][j]表示长度为i、最后一个数字为j的合法序列总数 dp[1][1...2000]都是1 后面用dp[i-1][j] 去更新 dp[i][j*t] (1 < j*t < 2000) 即用因子去更新它的倍数 表面上看是2000^3的复杂度会爆 其实不用…

解决:angularjs radio默认选中失效问题

添加ng-model后checked"checked"失效&#xff0c;可见angularjs也不好&#xff0c;会失效html标准属性解决&#xff1a;添加ng-checked"1"<input type"radio" ng-model"sel_course" value"1" ng-checked"1" /…

在ireport报错 报 jdk5找不到的解决办法

在ireport安装目录下&#xff0c; etc目录下有ireport.conf&#xff0c; 其中有jkdhome设置&#xff0c; 把前面的#&#xff08;注释&#xff09;去掉&#xff0c; 换成自己的jdk目录就行 双引号不要去掉 jdk地址放在双引号之间 比如 改成 jdkhome"G:/ACD/jdk1.5.0&quo…

如何通过中序和层序序列建立二叉树

有这样一棵二叉树 根据节点个数 9 层序遍历结果 15 23 8 16 2 32 28 7 11 中序遍历结果 16 23 7 32 11 2 28 15 8 预期先序输出 15 23 16 2 32 7 11 28 8 运行结果 这个过程和建立二叉查找树(BST)的过程是非常相像的&#xff0c;将laSq[laIndex]插入到根为root的子树中&a…

BZOJ 3573 米特运输

Description 米特是D星球上一种非常神秘的物质&#xff0c;蕴含着巨大的能量。在以米特为主要能源的D星上&#xff0c;这种米特能源的运输和储存一直是一个大问题。 D星上有N个城市&#xff0c;我们将其顺序编号为1到N&#xff0c;1号城市为首都。这N个城市由N-1条单向高速通…

[学习笔记]最小割之最小点权覆盖最大点权独立集

最小点权覆盖 给出一个二分图&#xff0c;每个点有一个非负点权要求选出一些点构成一个覆盖&#xff0c;问点权最小是多少 建模&#xff1a; S到左部点&#xff0c;容量为点权 右部点到T&#xff0c;容量为点权 左部点到右部点的边&#xff0c;容量inf 求最小割即可。 证明&…

10分钟学会Google Map API

http://space.itpub.net/14734354/viewspace-374828 前几天玩了玩Google的Map API&#xff0c;感觉还不错&#xff0c;很简单。但凡有过任何编程经验的同学&#xff0c;看完以下的教程&#xff0c;都可以在10分钟内掌握它的主要功能。另外我还做了个简单的小例子&#xff0c;有…