leetcode 1980. 找出不同的二进制字符串 中等

给你一个字符串数组 nums ,该数组由 n互不相同 的二进制字符串组成,且每个字符串长度都是 n 。请你找出并返回一个长度为 n没有出现nums 中的二进制字符串*。* 如果存在多种答案,只需返回 任意一个 即可。

示例 1:

复制代码
输入:nums = ["01","10"]
输出:"11"
解释:"11" 没有出现在 nums 中。"00" 也是正确答案。

示例 2:

复制代码
输入:nums = ["00","01"]
输出:"11"
解释:"11" 没有出现在 nums 中。"10" 也是正确答案。

示例 3:

复制代码
输入:nums = ["111","011","001"]
输出:"101"
解释:"101" 没有出现在 nums 中。"000"、"010"、"100"、"110" 也是正确答案。

提示:

  • n == nums.length
  • 1 <= n <= 16
  • nums[i].length == n
  • nums[i] '0''1'
  • nums 中的所有字符串 互不相同

分析:由于 n 的范围很小,可以从 0 开始检查长度为 n 的二进制整数是否出现过,如果没出现过,则输出。

cpp 复制代码
class Solution {
public:
    string trans(int num,int n,int pow_2[])
    {
        string ss="";
        for(int i=n-1;i>=0;--i)
        {
            if(num>=pow_2[i])ss+="1",num-=pow_2[i];
            else ss+="0";
        }
        return ss;
    }
    string findDifferentBinaryString(vector<string>& nums) {
        int pow_2[20]={1};
        for(int i=1;i<=16;++i)
            pow_2[i]=pow_2[i-1]*2;
        sort(nums.begin(),nums.end());

        int n=nums.size();
        for(int i=0;i<=pow_2[n];++i)
        {
            string s=trans(i,n,pow_2);
            if(i<n)
            {
                if(s!=nums[i])return s;
            }
            else return s;   
        }
        return "";
    }
};
相关推荐
硕风和炜2 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
凯瑟琳.奥古斯特4 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
tachibana26 小时前
hot100 回文链表(234)
java·网络·数据结构·leetcode·链表
wabs6669 小时前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月9 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
笨笨没好名字11 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
青山木13 小时前
Hot 100 --- LRU 缓存
java·数据结构·算法·leetcode·链表·缓存·哈希
想你依然心痛14 小时前
AtomCode在算法竞赛中的实战体验:LeetCode周赛辅助编程
linux·算法·leetcode
剑挑星河月15 小时前
35.搜索插入位置
java·数据结构·算法·leetcode
闪电悠米15 小时前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100