【力扣每日一题】2023.8.2 翻转卡片游戏

文章分析了一道编程题目,关于如何在翻转卡片游戏中找到一张卡片,其背面数字与所有卡片正面数字都不相同的最小值。通过逻辑简化,问题转化为找出不在正反面同时出现的最小数字。作者给出了C++代码实现了一个Solution类来解决此问题。
摘要由CSDN通过智能技术生成

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

这道题不是什么翻转卡片游戏,这就是纯纯的文字游戏,要是能看懂题目那就是非常简单,接下来我就给大家分析一下,我为什么这么说。

题目是说有N张卡片,每张卡片的正面和背面都分别有数字,并且以数组的形式给我们。

我们可以翻转任意卡片,来使得同一张卡片的正面和背面上的数字交换。

我们随意翻转之后,我们要找出一张卡片,这张背面的数字,和所有卡片正面的数字都不相同,让我们找出满足这样条件的最小的数。

题目有个坑就是正面和反面,我们不必太纠结正面反面的问题,因为我可以通过翻转全部卡片来让正面全部变成反面,而反面全部变成正面。

因此我们就把问题变成我要找一个最小数,这个数字只在本侧出现,而在另一侧找不到这个数字。

既然要让数字只在同一侧出现,那么只要不是某张卡片正面反面都是这个数字,那么我就可以通过翻转卡片来让数字归到同一侧。

再次化简题目,找出不是某张卡片正反面都是这个数字的最小数字

是不是一下子思路就清晰了起来,我们只需要从题目给的两个数组中,找出同一个索引的位置上是相同数字的元素,然后把这些相同的数字存起来,再次遍历两个数组,找出不是哪些数字的最小数字即可。找出不可能是答案的数,那剩下的不就是可能是答案的数了吗。

所以我说这道题能看懂题目的话就是非常简单。

代码:

class Solution {
public:
    int flipgame(vector<int>& fronts, vector<int>& backs) {
        unordered_set<int>s;
        int res=INT_MAX;
        //找出正反面相同的数字  
        for(int i=0;i<fronts.size();i++){    
            if(fronts[i]==backs[i]) s.insert(fronts[i]);
        }
        //只要不是正反面相同的数字,都可以通过翻转来使我不想对面(正面)有的数字翻转到自己这一面(背面)
        for(int i=0;i<fronts.size();i++){   
            if(s.count(fronts[i])==0) res=min(res,fronts[i]);
            if(s.count(backs[i])==0) res=min(res,backs[i]);
        }
        return res==INT_MAX?0:res;
    }
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值