八个月找不到工作了,35岁大龄程序员是不是完了。

科技   2024-11-14 10:10   上海  

精品推荐

《征服数据结构》专栏:50多种数据结构彻底征服

《经典图论算法》专栏:50多种经典图论算法全部掌握


一35岁程序员询问,已经八个月找不到工作了,是不是完了。如果是应届毕业生,互联网行业还是比较容易找工作的,就目前各互联网大厂开的薪资来看,还是比较高的,这说明互联网行业还是很缺人的,要不然每年也不会招那么多人,但这仅仅是对应届毕业生,与35岁以上的程序员无关。程序员35岁之后确实很难就业,35岁如果半年之内还找不到工作,基本上可以考虑转行了。





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


来看下今天的算法题,这题是LeetCode的第78题:子集。


问题描述



来源: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^len,其中len是数组的长度。

这题可以通过回溯算法或者二进制来解决,对于回溯算法也有两种解决方式,这个我们后面再讲,这里我们来看下使用二进制怎么解决。


对于所有在[0,2^len)之间的数字都可以看作是原数组一个子集的表示,对于当前数字如果某一位是 1 就表示需要选择对应的元素,如果是 0 就表示不选。比如示例 1 中子集的选择如下:


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;
    }

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


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

《征服数据结构》专栏

《征服数据结构》数组

《征服数据结构》稀疏表(Sparse Table)

《征服数据结构》单向链表

《征服数据结构》双向链表

《征服数据结构》块状链表

《征服数据结构》跳表

《征服数据结构》队列和循环队列

《征服数据结构》双端队列

《征服数据结构》单调队列

《征服数据结构》栈

《征服数据结构》单调栈

《征服数据结构》双端栈

《征服数据结构》散列表

《征服数据结构》堆

《征服数据结构》字典树(Trie树)

《征服数据结构》ArrayMap

《征服数据结构》SparseArray

《征服数据结构》二叉树

《征服数据结构》二叉搜索树(BST)

《征服数据结构》笛卡尔树

《征服数据结构》AVL树

《征服数据结构》树堆(Treap)

《征服数据结构》FHQ-Treap

《征服数据结构》哈夫曼树

《征服数据结构》Splay 树

《征服数据结构》Splay 树(二)

《征服数据结构》滚动数组

《征服数据结构》差分数组

《征服数据结构》并查集(DSU)

《征服数据结构》LRU缓存

《征服数据结构》LFU缓存

……


《经典图论算法》专栏

《经典图论算法》图的介绍

《经典图论算法》图的表示方式

《经典图论算法》邻接矩阵转换

《经典图论算法》广度优先搜索(BFS)

《经典图论算法》深度优先搜索(DFS)

《经典图论算法》A*搜索算法

《经典图论算法》迭代深化深度优先搜索(IDDFS)

《经典图论算法》IDA*算法

《经典图论算法》双向广度优先搜索

《经典图论算法》迪杰斯特拉算法(Dijkstra)

《经典图论算法》贝尔曼-福特算法(Bellman-Ford)

《经典图论算法》SPFA算法

《经典图论算法》弗洛伊德算法(Floyd)

《经典图论算法》卡恩(Kahn)算法

《经典图论算法》基于DFS的拓扑排序

《经典图论算法》约翰逊算法(Johnson)

《经典图论算法》普里姆算法(Prim)

《经典图论算法》克鲁斯卡尔算法(Kruskal)

《经典图论算法》博鲁夫卡算法(Boruvka)

……


数据结构和算法
王一博,《算法秘籍》作者,1000多页的pdf算法题我也已经整理完成,在公众号“数据结构和算法”中回复关键字“pdf”即可下载。
 最新文章