真是被震惊到了,形势比想象的严峻多了。。。

6098db9cce9d06a4e2b5d5603c0e24ef.gif

(关注数据结构和算法,了解更多新知识)

一网友发文说今年的形势比想象的严峻的多,原因是他最近想找以前的同事帮忙内推看有没有啥工作机会,结果问了一圈,除了一个已经跳到国企上岸了的,其余的竟然全都在家待业。。。。。。

79f70d4dc532f6b513bb7b211f30035f.png

最近几年基本上每年都会有不少人抱怨,今年形势比去年严峻,实际上每年都会有大量的人失业,也都会有大量的人就业,用网友的一句话说就是:旱的旱死,涝的涝死。

还有这种情况实际上也和自己的圈子有关,有些人身边失业的很少,基本上都有工作,而有些人身边失业的确实比较多,我们来看下各位网友目前面临的情况。

8b472130c862a69ed8c98cb521d63233.png

4d707dc1b6596dc4c2ba99ad01fd95b8.png

e6511df75c2ba5b086e322af8db6f5b0.png

--------------下面是今天的算法题--------------

来看下今天的算法题,这题是LeetCode的第78题:子集。这题也是字节的面试题,我们来看下。

bf9a6bd63062ea27f7412e14c7e15632.png

问题描述

来源:LeetCode第78题

难度:中等

给你一个整数数组 nums ,数组中的元素互不相同 。返回该数组所有可能的

子集幂集)。解集不能包含重复的子集。你可以按任意顺序返回解集。

示例1:

输入:nums = [1,2,3]

输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例2:

输入:nums = [0]

输出:[[],[0]]

  • 1 <= nums.length <= 10

  • -10 <= nums[i] <= 10

  • nums 中的所有元素互不相同

问题分析

这题让返回数组的所有子集,把原数组中的某些元素去掉之后就是其中的一个子集。对于每个元素都有两种状态,一种是选择一种是不选择,所以总的子集数量是2^length,其中length是数组的长度。

我们可以通过二进制的方式来计算,对于所有在[0,2^length)之间的数字都可以看作是原数组一个子集的表示,对于当前数字如果某一位是1就表示需要选择对应的元素,如果是0就表示不选。比如示例1中子集的选择如下:

df85173d051cc8d929c7347977e1bef0.png

JAVA:

public List<List<Integer>> subsets(int[] nums) {
    List<List<Integer>> ans = new ArrayList<>();
    int total = 1 << nums.length;// 总的子集个数
    for (int i = 0; i < total; i++) {
        List<Integer> subList = new ArrayList<>();
        for (int j = 0; j < nums.length; j++) {
            // 如果数字 i 的某一位上是 1 就选择。
            if ((i & (1 << j)) != 0)
                subList.add(nums[j]);
        }
        ans.add(subList);
    }
    return ans;
}

C++:

public:
    vector<vector<int>> subsets(vector<int> &nums) {
        vector<vector<int>> ans;
        int total = 1 << nums.size();// 总的子集个数
        for (int i = 0; i < total; i++) {
            vector<int> subList;
            for (int j = 0; j < nums.size(); j++) {
                // 如果数字 i 的某一位上是 1 就选择。
                if ((i & (1 << j)) != 0)
                    subList.push_back(nums[j]);
            }
            ans.push_back(subList);
        }
        return ans;
    }

C:

int **subsets(int *nums, int numsSize, int *returnSize, int **returnColumnSizes) {
    int total = 1 << numsSize;// 总的子集个数
    int **ans = malloc(total * sizeof(int *));
    *returnColumnSizes = malloc(total * sizeof(int));
    memset(*returnColumnSizes, 0, total * sizeof(int));
    *returnSize = 0;
    for (int i = 0; i < total; i++) {
        ans[*returnSize] = malloc(numsSize * sizeof(int));
        for (int j = 0; j < numsSize; j++) {
            // 如果数字 i 的某一位上是 1 就选择。
            if ((i & (1 << j)) != 0)
                ans[*returnSize][(*returnColumnSizes)[*returnSize]++] = nums[j];
        }
        (*returnSize)++;
    }
    return ans;
}

Python:

def subsets(self, nums: List[int]) -> List[List[int]]:
    ans = []
    total = 1 << len(nums)  # 总的子集个数
    for i in range(total):
        subList = []
        for j in range(len(nums)):
            # 如果数字 i 的某一位上是 1 就选择。
            if (i & (1 << j)) != 0:
                subList.append(nums[j])
        ans.append(subList)
    return ans

d8a57f1e5cd33816b30e815e24a8ab1b.gif

笔者简介

博哥,真名:王一博,毕业十多年,《算法秘籍》作者,专注于数据结构和算法的讲解,在全球30多个算法网站中累计做题2000多道,在公众号中写算法题解800多题,对算法题有自己独特的解题思路和解题技巧,喜欢的可以给个关注,也可以下载我整理的1000多页的PDF算法文档。

  • 24
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在古老的村庄里,有一位名叫李富的木匠。他是个善良勤劳的人,每天都会辛勤地工作,赚取自己的生活费用。然而,有一天晚上,他经历了一次奇妙的经历。 那天晚上,李富加班到很晚,直到夜深人静的时候才回家。在回家的路上,他经过了一条小溪,发现一位老翁正站在河岸边,想要过河。老翁身上的衣服已经湿透了,显然他已经等了很久,但是没有人愿意帮助他过河。 李富看到老翁的困境,便主动问道:“老爷子,您需要帮忙吗?我可以背您过河。” 老翁欣然同意了,李富背着老翁,小心翼翼地穿过了泥泞的小溪。当他们到达对岸时,老翁感激地说:“谢谢你,年轻人。你真是个好人。” 李富笑着回答道:“没什么,老爷子。这只是我应该做的。” 然而,老翁突然说道:“但是,你千万不要进入那座破庙里避雨。” 李富感到很奇怪,问道:“为什么呢?” 老翁沉默了一会儿,然后说道:“那里是一个恶灵的栖息地。如果你进去了,他会抓住你,让你永远也出不去。” 听到这些话,李富感到很害怕,但他还是决定遵守老翁的话。他继续沿着路走,直到他看到了那座破旧的庙宇。雨越来越大,他感到很冷,但他仍然决定不要进去。 突然,他听到了一声尖叫声,然后是一阵可怕的咆哮声。他感到很害怕,但他仍然决定不要进去。他继续走着,直到他回到了自己的家里。 但是,这次经历却留给了他深刻的印象。他开始怀疑老翁的话是否真实,但是他又觉得自己很幸运没有进去。他开始对那个庙宇产生了一种奇怪的恐惧,甚至连经过的时候都会加快自己的步伐。 几天后,李富再次经过那个庙宇,他看到了一个鬼魂,它坐在庙宇的门口,看着他。他太害怕了,以至于他差点晕倒了。他决定再也不去那个地方了,甚至连这个话题都不敢说出口。 然而,他的经历并没有结束。有一天晚上,他在家里睡觉时,听到了一阵奇怪的声音。他打开了窗户,看到了那个老翁。他惊讶地问道:“老爷子,你怎么会在这里?” 老翁微笑着回答道:“我是来感谢你的。你救了我的命,并且遵守了我的建议。” 李富感到很奇怪,问道:“你是谁?为什么要警告我不要进那个庙宇?” 老翁沉默了一会儿,然后说道:“我是那个庙宇里的恶灵。” 听到这个话,李富感到很震惊,但他还是决定听老翁的话。他问道:“你为什么会告诉我这些?” 老翁微笑着回答道:“因为你是一个好人。你救了我的命,并且遵守了我的建议。我相信你是一个诚实的人,并且你不会伤害别人。” 听到这个话,李富感到很惊讶。他意识到,老翁并不是那么可怕,他只是一个被困在那个庙宇里的灵魂。他感到很同情,决定帮助老翁。 李富决定带上一些香烛和纸钱,前往那个庙宇。当他到达那里时,他看到了老翁。老翁感到很高兴,他告诉李富,只要他给他点香烛和纸钱,他就可以离开这个世界了。 李富感到很高兴,他点燃了香烛和纸钱,然后离开了那个庙宇。当他回到家里时,他感到很轻松,他意识到他帮助了一个需要帮助的人。从那一天起,他开始了一段新的生活,他变得更加善良,更加关心别人。 这个故事告诉我们,善良是一种美德,它能够帮助我们成为更好的人。如果我们能够关注别人的需要,并且尽力帮助他们,我们将会获得更多的快乐和满足。即使我们遇到了困难,我们也应该坚持自己的信念,相信自己的行为是正确的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据结构和算法

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值