LeetCode 2151. 基于陈述统计最多好人数(状态压缩)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

游戏中存在两种角色:

  • 好人:该角色只说真话
  • 坏人:该角色可能说真话,也可能说假话。

给你一个下标从 0 开始的二维整数数组 statements ,大小为 n x n ,表示 n 个玩家对彼此角色的陈述。

具体来说,statements[i][j] 可以是下述值之一:

  • 0 表示 i 的陈述认为 j 是 坏人
  • 1 表示 i 的陈述认为 j 是 好人
  • 2 表示 i 没有对 j 作出陈述。

另外,玩家不会对自己进行陈述。形式上,对所有 0 <= i < n ,都有 statements[i][i] = 2

根据这 n 个玩家的陈述,返回可以认为是 好人最大 数目。

示例 1:
在这里插入图片描述

输入:statements = [[2,1,2],[1,2,2],[2,0,2]]
输出:2
解释:每个人都做一条陈述。
- 0 认为 1 是好人。
- 1 认为 0 是好人。
- 2 认为 1 是坏人。
以 2 为突破点。
- 假设 2 是一个好人:- 基于 2 的陈述,1 是坏人。- 那么可以确认 1 是坏人,2 是好人。- 基于 1 的陈述,由于 1 是坏人,那么他在陈述时可能:- 说真话。在这种情况下会出现矛盾,所以假设无效。- 说假话。在这种情况下,0 也是坏人并且在陈述时说假话。- 在认为 2 是好人的情况下,这组玩家中只有一个好人。
- 假设 2 是一个坏人:- 基于 2 的陈述,由于 2 是坏人,那么他在陈述时可能:- 说真话。在这种情况下,01 都是坏人。- 在认为 2 是坏人但说真话的情况下,这组玩家中没有一个好人。- 说假话。在这种情况下,1 是好人。- 由于 1 是好人,0 也是好人。- 在认为 2 是坏人且说假话的情况下,这组玩家中有两个好人。
在最佳情况下,至多有两个好人,所以返回 2 。
注意,能得到此结论的方法不止一种。

示例 2:
在这里插入图片描述

输入:statements = [[2,0],[0,2]]
输出:1
解释:每个人都做一条陈述。
- 0 认为 1 是坏人。
- 1 认为 0 是坏人。
以 0 为突破点。
- 假设 0 是一个好人:- 基于与 0 的陈述,1 是坏人并说假话。- 在认为 0 是好人的情况下,这组玩家中只有一个好人。
- 假设 0 是一个坏人:- 基于 0 的陈述,由于 0 是坏人,那么他在陈述时可能:- 说真话。在这种情况下,01 都是坏人。- 在认为 0 是坏人但说真话的情况下,这组玩家中没有一个好人。- 说假话。在这种情况下,1 是好人。- 在认为 0 是坏人且说假话的情况下,这组玩家中只有一个好人。
在最佳情况下,至多有一个好人,所以返回 1 。 
注意,能得到此结论的方法不止一种。提示:
n == statements.length == statements[i].length
2 <= n <= 15
statements[i][j] 的值为 012
statements[i][i] == 2

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-good-people-based-on-statements
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • n比较小,把每个人是好人还是坏人的实际情况看成 int 的 n 位 01 二进制位
  • 枚举每种状态,遍历该状态下的好人说的话有没有矛盾的
class Solution {
public:int maximumGood(vector<vector<int>>& statements) {int n = statements.size(), ans = 0;for(int state = 1; state < (1<<n); ++state){bool stop = false;int count = 0;for(int j = 0; j < n; ++j){ // 遍历该状态下每个人是好人还是坏人if((state>>j)&1) // j 是好人{count++;for(int k = 0; k < n; ++k){	// 好人说的话if(statements[j][k]<2){ if(statements[j][k] == ((state>>k)&1) )	// 没有矛盾continue;else{stop = true;break;}}}if(stop)break;}}if(!stop)//该状态所有好人说的话都没有矛盾ans = max(ans, count);}return ans;}
};

112 ms 8.2 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/471243.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

七、操作系统——动态分区分配算法(详解)

一、引入 动态分区分配算法&#xff1a;在动态分区分配方式中&#xff0c;当很多个空闲分区都能满足需求时&#xff0c;应该选择哪个分区进行分配&#xff1f; 二、首次适应算法&#xff08;First Fit&#xff09; 算法思想&#xff1a;每次都从低地址开始查找&#xff0c;…

2015前端生态发展回顾(转)

引用苏宁前端架构师的一个总结作为开篇 编程技术及生态发展的三个阶段 最初的时候人们忙着补全各种API&#xff0c;代表着他们拥有的东西还很匮乏&#xff0c;需要在语言跟基础设施上继续完善然后就开始各种模式&#xff0c;标志他们做的东西逐渐变大变复杂&#xff0c;需要更好…

计算机应用基础一级考试题库,2018一级结构工程师《计算机应用基础》题库及答案(一)...

大家做好准备迎接考试了吗?出国留学网为您整理了“2018一级结构工程师《计算机应用基础》题库及答案(一)”&#xff0c;只要付出了辛勤的劳动&#xff0c;总会有丰硕的收获!欢迎广大考生前来学习。2018一级结构工程师《计算机应用基础》题库及答案(一)1. 具有多媒体功能的微型…

LeetCode 2154. 将找到的值乘以 2

文章目录1. 题目2. 解题1. 题目 给你一个整数数组 nums &#xff0c;另给你一个整数 original &#xff0c;这是需要在 nums 中搜索的第一个数字。 接下来&#xff0c;你需要按下述步骤操作&#xff1a; 如果在 nums 中找到 original &#xff0c;将 original 乘以 2 &#…

网际控制报文协议ICMP(Internet Control Message Protocol)(详解)

一、回顾下TCP/IP协议栈 二、ICMP(Internet Control Message Protocol)协议概述 三、ICMP协议的组成 四、ICMP差错报告报文&#xff08;5种&#xff09;&#xff1a; 终点不可达&#xff1a;当路由器或主机不能交付数据报时就向源点发送终点不可达报文。&#xff08;无法交付&…

计算机一级实训报告册,计算机一级实验报告8.doc

文档介绍&#xff1a;计算机应用教学实验报告《计算机应用》课程实验报告实验地点:实验名称实验八Word2010图文混排指导教师时间姓名班级学号15128201组号同组者姓名评分实验目的1、熟练掌握在文档中插入各种对象的方法。2、掌握各种图形对象的格式设置。3、掌握嵌入式图片和浮…

王道考研学习笔记IP数据报格式IP数据报分片(超详细)

一、回顾TCP/IP协议栈 二、IP数据报格式 记忆方法&#xff1a; TCP是面向连接的服务&#xff0c;面向连接就非常6。而UDP是不面向连接的&#xff0c;数据就非常容易被“遗弃”&#xff08;17&#xff09;。因为如果不建立连接&#xff0c;这个链路是不太可靠的&#xff0c;所以…

LeetCode 2155. 分组得分最高的所有下标(前缀和)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的二进制数组 nums &#xff0c;数组长度为 n 。 nums 可以按下标 i&#xff08; 0 < i < n &#xff09;拆分成两个数组&#xff08;可能为空&#xff09;&#xff1a;numsleft 和 numsright 。 numsleft 包含 nu…

ConvertFrom-String 命令研究

-------先上个例子------- $aaa 0.027 0.034 0.834 0.1050.346 0.558 0.018 0.0780.001 0.997 0.001 0.0010.994 0.001 0.004 0.0010.001 0.996 0.002 0.0010.001 0.001 0.997 0.0010.001 0.009 0.001 0.9890.051 0.111 0.837 0.001 $t {字段名1*:0.027} {字段名2:0.034} {字…

强基计划对计算机,你对报考强基计划怎么看?

原标题&#xff1a;你对报考强基计划怎么看&#xff1f;提起“强基计划”&#xff0c;可能是近期高三家长们、考生们提到最多的话题了&#xff0c;尤其是高校的强基计划招生章程发布之后&#xff0c;关于“强基计划”的咨询量明显上升了许多&#xff0c;那么对于今年第一年实施…

路由算法及路由协议(详解)

一、路由算法 最佳路由&#xff1a;“最佳”只能是相对于某一种特定要求下得出的较为合理的选择而已。 二、路由算法的分类 三、分层次的路由选择协议 为什么要采用分层次的路由选择协议呢&#xff1f; 因特网规模很大许多单位不想让外界知道自己的路由选择协议&#xff0c;…

LeetCode 2156. 查找给定哈希值的子串(字符串哈希)

文章目录1. 题目2. 解题1. 题目 给定整数 p 和 m &#xff0c;一个长度为 k 且下标从 0 开始的字符串 s 的哈希值按照如下函数计算&#xff1a; hash(s,p,m)(val(s[0])∗p0val(s[1])∗p1...val(s[k−1])∗pk−1)modmhash(s,p,m) (val(s[0])*p^0 val(s[1])*p^1...val(s[k-1])…

二维码扫描利用ZBar实现

上次是根据系统的属性自己封装的一个二维码扫描&#xff0c;这次给大家介绍一下基于ZBar集成的类似于QQ二维码扫描界面的二维码扫描的效果。 最下方配有效果图哦&#xff01; 首先&#xff0c;需要引入ZBar第三方库文件&#xff1a; ZBarSDK libqrencode 其次&#xff0c;利用Z…

十二、一篇文章帮助你快速读懂MySQL索引(B树、B+树详解)

2. 索引 2.1 索引概述 MySQL官方对索引的定义为&#xff1a;索引&#xff08;index&#xff09;是帮助MySQL高效获取数据的数据结构&#xff08;有序&#xff09;。在数据之外&#xff0c;数据库系统还维护者满足特定查找算法的数据结构&#xff0c;这些数据结构以某种方式引…

叛乱2正版怎么创服务器,Insurgency Linux Server 叛乱2创建服务器教程(转steam指南)

// ---------------------------------------------------------------// Server Info Options// ---------------------------------------------------------------sv_playlist nwi/pvp_sustained //标准合作sv_pure -1 //支持MODhostname "#2[cn]www.xiongtianqi.cn qu…

LeetCode 2157. 字符串分组(状态压缩+位运算+图的遍历)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的字符串数组 words 。 每个字符串都只包含 小写英文字母 。words 中任意一个子串中&#xff0c;每个字母都至多只出现一次。 如果通过以下操作之一&#xff0c;我们可以从 s1 的字母集合得到 s2 的字母集合&#xff0c;…

常见的getchar 与EOF的问题

代码中常有类似的如下的输入循环 char c;   while((cgetchar())!EOF).... 如果输入 字符换行时&#xff0c;循环的代码会执行两次&#xff0c;主要是换行键作为字符存到了缓存队列中&#xff0c;第一次c为输入的值&#xff0c;第二次c为换行符 &#xff0c;可以通过fflush(s…

谷歌插件开发ajax请求,chrome插件 注入js以及发送ajax(message/request)

manifest.json 内容知识点包含&#xff1a;* content_scripts注入js&#xff0c;background.scripts用来发送请求(content_scripts禁止发送ajax)* Message 和 Request 区别manifestJavaScript{"name":"Catch your Data","description":"Cat…

JavaScript+ Canvas开发趣味小游戏《贪吃蛇》

一、效果展示 二、《贪吃蛇》基本实现思路 蛇头部分蛇身体部分&#xff1a;采用对象形式来存储坐标&#xff0c;并将每个坐标对象放到一个snake数组中&#xff0c;方便使用。设置每个方格宽度30px,高度30px&#xff0c;画布高度600px&#xff0c;宽度600px。 a.新蛇头newHead等…

LeetCode 2160. 拆分数位后四位数字的最小和

文章目录1. 题目2. 解题1. 题目 给你一个四位 正 整数 num 。请你使用 num 中的 数位 &#xff0c;将 num 拆成两个新的整数 new1 和 new2 。 new1 和 new2 中可以有 前导 0 &#xff0c;且 num 中 所有 数位都必须使用。 比方说&#xff0c;给你 num 2932 &#xff0c;你拥…