当前位置: 首页 > news >正文

php做网站优势win系统更新后 wordpress

php做网站优势,win系统更新后 wordpress,什么是网络公司,网站设计会存在什么问题大厂工时爆料 今天逛脉脉的时候,看到一篇名为「一人一句,大厂工时爆料」的帖子: 点开之后,我沉默了 ... 出来爆料的基本上都是 10 小时。 好奇心之下,我搜索了一下去年很热的排行榜: 2023 年最新互联网公司…

大厂工时爆料

今天逛脉脉的时候,看到一篇名为「一人一句,大厂工时爆料」的帖子:

alt

点开之后,我沉默了 ...

出来爆料的基本上都是 10+ 小时。

alt

好奇心之下,我搜索了一下去年很热的排行榜:

2023 年最新互联网公司工作时长排行榜(来源网络)
2023 年最新互联网公司工作时长排行榜(来源网络)

好家伙,依然稳定。

如果是偶尔赶项目,加班一下能理解,去年周工作时长已经长达 60+ 小时,今年还被爆料日均 10+ 个小时,说明内卷已经成为日常了。

过去几年,各行各业都羡慕计算机行业,但大多围城外的人只看到巨额年终,而看不到超低时薪。

对此,你怎么看?欢迎新建「匿名身份」在评论区爆料你的工时(貌似还很多同学不知道公众号新出的这功能,有段时间了

...

回归主题。

来一道不算容易的,和「字节跳动(社招四面)」相关的题目。

题目描述

平台:LeetCode

题号:862

给你一个整数数组 nums 和一个整数 k ,找出 nums 中和至少为 k 的最短非空子数组,并返回该子数组的长度。

如果不存在这样的子数组,返回 -1

子数组是数组中连续的一部分。

示例 1:

输入:nums = [1], k = 1

输出:1

示例 2:

输入:nums = [1,2], k = 4

输出:-1

示例 3:

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

输出:3

提示:

前缀和 + 离散化 + 权值树状数组

由于求解的对象是子数组,容易联想到求连续段之和,容易联想到「前缀和」,假设我们预处理出的前缀和数组为 sum(为了方便,我们令前缀和数组坐标从 1 开始)。

即每个 而言,本质上是找满足「 」条件的最大下标 j,其中 j 的取值范围为 ,从而知道以 i 作为右端点时,满足条件的最短子数组长度为

先考虑存在负数域的问题,由于我们需要使用 ,以及对应的 ,同时 k 的取值为 (过大),我们可以通过「离散化」手段将其映射到 2 倍的数组长度,即大小为 的正数域。

随后来考虑如何求解「满足条件的最大下标」问题,可以通过「权值树状数组」来做:对于每个 而言,我们利用「权值树状数组」来维护满足大于等于 的最大下标。起始我们先初始化树状数组为 -1,遍历过程中,查询是否存在满足条件的下标(若不为 -1 则更新 ans),并更新权值树状数组对应的最大下标即可。

Java 代码:

class Solution {
    static int N = 200010;
    static int[] tr = new int[N], sum = new int[N];
    int n, m, ans;
    int lowbit(int x) {
        return x & -x;
    }
    void update(int val, int loc) {
        for (int i = val; i < m; i += lowbit(i)) tr[i] = Math.max(tr[i], loc);
    }
    int query(int x) {
        int ans = -1;
        for (int i = x; i > 0; i -= lowbit(i)) ans = Math.max(ans, tr[i]);
        return ans;
    }
    int getIdx(List<Long> list, long x) {
        int l = 0, r = list.size() - 1;
        while (l < r) {
            int mid = l + r >> 1;
            if (list.get(mid) >= x) r = mid;
            else l = mid + 1;
        }
        return r + 1;
    }
    public int shortestSubarray(int[] nums, int k) {
        n = nums.length; m = 2 * n + 10; ans = n + 10;
        Arrays.fill(tr, -1);
        long[] temp = new long[m];
        List<Long> list = new ArrayList<>();
        list.add(0L);
        for (int i = 1; i <= 2 * n + 1; i++) {
            if (i <= n) temp[i] = temp[i - 1] + nums[i - 1];
            else temp[i] = temp[i - (n + 1)] + k;
            list.add(temp[i]);
        }
        Collections.sort(list);
        for (int i = 0; i <= 2 * n + 1; i++) sum[i] = getIdx(list, temp[i]);
        update(sum[n + 1], 0);
        for (int i = 1; i <= n; i++) {
            int j = query(sum[i]);
            if (j != -1) ans = Math.min(ans, i - j);
            update(sum[n + 1 + i], i);
        }
        return ans == n + 10 ? -1 : ans;
    }
}

C++ 代码:

class Solution {
public:
    static const int N = 200010;
    vector<int> tr, sum;
    int n, m, ans;
    int lowbit(int x) {
        return x & -x;
    }
    void update(int val, int loc) {
        for (int i = val; i < m; i += lowbit(i)) tr[i] = max(tr[i], loc);
    }
    int query(int x) {
        int ans = -1;
        for (int i = x; i > 0; i -= lowbit(i)) ans = max(ans, tr[i]);
        return ans;
    }
    int shortestSubarray(vector<int>& nums, int k) {
        n = nums.size(); m = 2 * n + 10; ans = n + 10;
        tr.resize(m, -1); sum.resize(m + 100);
        vector<long longtemp(m);
        vector<long longlist;
        for (int i = 1; i <= 2 * n + 1; i++) {
            if (i <= n) temp[i] = temp[i - 1] + nums[i - 1];
            else temp[i] = temp[i - (n + 1)] + k;
            list.push_back(temp[i]);
        }
        sort(list.begin(), list.end());
        for (int i = 0; i <= 2 * n + 1; i++) {
            sum[i] = lower_bound(list.begin(), list.end(), temp[i]) - list.begin() + 1;
        }
        update(sum[n + 1], 0);
        for (int i = 1; i <= n; i++) {
            int j = query(sum[i]);
            if (j != -1) ans = min(ans, i - j);
            update(sum[n + 1 + i], i);
        }
        return ans == n + 10 ? -1 : ans;
    }
};
  • 时间复杂度:预处理前缀和的的复杂度为 ,排序并进行离散化的复杂度为 ;构造答案的复杂度为 。整体复杂度为
  • 空间复杂度:

最后

给大伙通知一下 📢 :

全网最低价 LeetCode 会员目前仍可用 ~

📅 年度:有效期加赠两个月!!; 季度:有效期加赠两周!!

🧧 年度:获 66.66!!; 季度:获 22.22!!

🎁 年度:参与当月丰厚专属实物抽奖(中奖率 > 30%)!!

专属链接:leetcode.cn/premium/?promoChannel=acoier

我是宫水三叶,每天都会分享算法知识,并和大家聊聊近期的所见所闻。

欢迎关注,明天见。

更多更全更热门的「笔试/面试」相关资料可访问排版精美的 合集新基地 🎉🎉

http://www.yayakq.cn/news/164442/

相关文章:

  • 网站建设进度报告wordpress静态资源加载不
  • 湖北做网站推广网络推广服务合同范本
  • 石龙网站建设简单的购物网站项目
  • 小米商城网站建设网站建设的实验报告
  • 中山网站建设半江红如何建立网站建设规划
  • 带屏蔽的网站做水晶头网站开发的质量标准
  • 做房地产网站广告销售室内设计师服务平台
  • 公司网站推广方案株洲网站建设平台
  • qq推广引流怎么做宝安网站建设seo信科
  • 网站怎样做微信公众号公司网站备案必须是企业信息么
  • 现在网站建设用什么软件如何快速推广
  • 南昌市有帮做网站的吗网站制作前景
  • 佛山中小企业外贸网站建设推广网站产品 模块
  • 国外做任务的网站开发一款软件需要多少钱?
  • 做交通分析的网站专业的建设网站
  • 不一样的婚恋网站怎么做长沙功能网站建设
  • 如何下载网站模板云南住房和城乡建设部网站
  • 电子商务网站建设行情珠海网站建设尚古道策略
  • 菜鸟移动端网站开发电商种类有哪些
  • 织梦怎么建设论坛网站网络游戏企业不可以在哪个时间段
  • 个性化网站建设大庆工程建设公司网站
  • 老河口网站定制把WordPress搬家
  • 怎么给网站上传附件深圳营业执照网上申报入口
  • php网站开发 pdf网站ome系统怎么做
  • 电站建设招聘网站快速网站建设多少钱
  • 单页面营销网站网易企业邮箱登录登录入口
  • 网站建设怎么添加评论网站开发在线培训
  • 临清做网站推广恒彩装饰公司口碑
  • 网站套餐到期是什么意思青岛网站策划
  • 做网站必须要文网文吗wordpress 编辑器 图片上传