力扣第 365 场周赛虚拟参赛

news2025/1/15 20:51:15

有序三元组中的最大值 I

class Solution {
public:
    long long maximumTripletValue(vector<int>& nums) {
        vector<long long> num;
        for (auto &item:nums) {
            num.push_back(item*1ll);
        }
        long long z = 0,f = 1000000;
        long long ans = 0;
        long long maxx = num[0],minn = num[0];
        for (int i = 1;i < nums.size();i ++) {
            if (i > 1 ) {
                if (nums[i] > 0) {
                    ans = max(ans,num[i]*z);
                } else {
                    ans = max(ans,num[i]*f);
                }
            }
            z = max(z,maxx-num[i]);
            f = min(f,minn-num[i]);
            minn = min(minn,num[i]);
            maxx = max(maxx,num[i]);
        }
        return ans;
    }
};

有序三元组中的最大值 II

class Solution {
public:
    long long maximumTripletValue(vector<int>& nums) {
        vector<long long> num;
        for (auto &item:nums) {
            num.push_back(item*1ll);
        }
        long long z = 0,f = 1000000;
        long long ans = 0;
        long long maxx = num[0],minn = num[0];
        for (int i = 1;i < nums.size();i ++) {
            if (i > 1 ) {
                if (nums[i] > 0) {
                    ans = max(ans,num[i]*z);
                } else {
                    ans = max(ans,num[i]*f);
                }
            }
            z = max(z,maxx-num[i]);
            f = min(f,minn-num[i]);
            minn = min(minn,num[i]);
            maxx = max(maxx,num[i]);
        }
        return ans;
    }
};

无限数组的最短子数组

  • 题意
    在这里插入图片描述
  • 思路
    把target/nums_sum 个数加上,剩下的就是拼接一下找最短子数组
class Solution {
public:
    int minSizeSubarray(vector<int> &nums, int target) {
        long long total = accumulate(nums.begin(), nums.end(), 0LL);
        int n = nums.size();
        int ans = INT_MAX;
        int left = 0;
        long long sum = 0;
        for (int right = 0; right < n * 2; right++) {
            sum += nums[right % n];
            while (sum > target % total) {
                sum -= nums[left++ % n];
            }
            if (sum == target % total) {
                ans = min(ans, right - left + 1);
            }
        }
        return ans == INT_MAX ? -1 : ans + target / total * n;
    }
};


有向图访问计数(待补)

  • 题意
    在这里插入图片描述
  • 思路
    在这里插入图片描述
  • 代码
class Solution {
public:
    vector<int> countVisitedNodes(vector<int>& edges) {
        int n = edges.size();
        // e[sn] 表示从 sn 出发的反向边(即原图以 sn 为终点的边)
        vector<int> e[n];
        for (int i = 0; i < n; i++) e[edges[i]].push_back(i);

        // vis 数组用来求环长
        int vis[n];
        memset(vis, 0, sizeof(vis));
        // dis[i] 表示从点 i 走到环上的距离
        int dis[n];
        memset(dis, -1, sizeof(dis));

        vector<int> ans(n);
        // 对每个连通块分别求答案
        for (int S = 0; S < n; S++) if (dis[S] == -1) {
            // 从任意一点出发,都能走到环上,模拟求环长
            int now = S, cnt = 1;
            for (; vis[now] == 0; now = edges[now], cnt++) vis[now] = cnt;
            int loop = cnt - vis[now];
            
            // 从环上每个点开始,在反向边上 bfs,求每个点走到环上的距离
            queue<int> q;
            q.push(now); dis[now] = 0;
            for (int sn = edges[now]; sn != now; sn = edges[sn]) q.push(sn), dis[sn] = 0;
            while (!q.empty()) {
                int sn = q.front(); q.pop();
                // 答案就是环长 + 走到环上的距离
                ans[sn] = dis[sn] + loop;
                for (int fn : e[sn]) if (dis[fn] == -1) {
                    q.push(fn);
                    dis[fn] = dis[sn] + 1;
                }
            }
        }

        return ans;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1057820.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

凉鞋的 Godot 笔记 105. 第一个通识:编辑-测试 循环

105. 第一个通识&#xff1a;编辑-测试 循环 在这一篇&#xff0c;我们简单聊聊此教程中所涉及的一个非常重要的概念&#xff1a;循环。 我们在做任何事情都离不开某种循环&#xff0c;比如每天的 24 小时循环&#xff0c;一日三餐循环&#xff0c;清醒-睡觉循环。 在学习一…

【SLAM数学基础】李群与李代数 BCH近似公式

三维旋转构成了三维旋转群 SO(3)&#xff0c;其对应的李代数为 s o \mathfrak{so} so(3)&#xff1b;三维变换构成了三维变换群 SE(3)&#xff0c;其对应的李代数为 s e \mathfrak{se} se(3)。 1.指数映射 李代数元素到李群元素的映射为指数映射&#xff0c;其中 s o \mat…

代码随想录算法训练营第五十五天 | 动态规划 part 12 | 300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组

目录 300.最长递增子序列思路代码 674. 最长连续递增序列思路代码 718. 最长重复子数组思路代码 300.最长递增子序列 Leetcode 思路 dp[i]表示i之前包括i的以nums[i]结尾的最长递增子序列的长度递推公式&#xff1a;if (nums[i] > nums[j]) dp[i] max(dp[i], dp[j] 1)初…

力扣:118. 杨辉三角(Python3)

题目&#xff1a; 给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官…

linux 笔记:远程服务器登录jupyter notebook

1 生成jupyter notebook 配置文件&#xff08;服务器端&#xff09; jupyter notebook --generate-config #Writing default config to: /home/shuailiu/.jupyter/jupyter_notebook_config.py2 Ipython中设置密码&#xff08;服务器端&#xff09; 3 修改jupyter 配置文件&…

QT实现TCP服务器客户端搭建的代码,现象

1.效果 2.服务器&#xff1a; 2.1&#xff1a;ui界面 2.2&#xff1a;头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTcpServer> #include <QTcpSocket> #include <QList> #include <QMessageBox> #include <QDeb…

pip常用操作

目录 1. 下载库1.1. 常规安装1.1.1. 不指定版本(默认为最新)1.1.2. 指定版本 1.2. 配置镜像1.2.1. 使用临时镜像1.2.2. 使用永久镜像1.2.2.1. 命令行配置1.2.2.2. 配置文件配置 2. 删除库3. 删除缓存4. 更新4.1. 更新pip4.2. 更新某个包 5. 项目依赖文件5.1. 给项目添加 requir…

(高阶) Redis 7 第18讲 RedLock 分布式锁

🌹 以下分享 RedLock 分布式锁,如有问题请指教。🌹🌹 如你对技术也感兴趣,欢迎交流。🌹🌹🌹 如有对阁下帮助,请👍点赞💖收藏🐱‍🏍分享😀 问题 分布式锁问题从(高阶) Redis 7 第17讲 分布式锁 实战篇_PJ码匠人的博客-CSDN博客 这篇文章来看,…

基于Java的宠物用品商城设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…

vscode 注释插件koroFileHeader

https://blog.51cto.com/u_15785499/5664323 https://blog.csdn.net/weixin_67697081/article/details/129004675

【精彩回顾】 用sCrypt在Bitcoin上构建智能合约(2)

2023年3月30日&#xff0c;sCrypt首席执行官刘晓晖在英国伦敦nChain做了题为“用sCrypt在Bitcoin上构建智能合约”的演讲&#xff0c;并与现场来宾进行了深入交流、互动。这次课程着重讲解了 BSV 智能合约的基础概念&#xff0c;以及如何利用 sCrypt 的相关工具构建应用。 ▲英…

密码技术 (6) - 证书

一. 前言 前面介绍的公钥密码和数字签名&#xff0c;都无法解决一个问题&#xff0c;那就是判断自己获取的公钥是否期望的&#xff0c;不能确定公钥是否被中间攻击人掉包。所以&#xff0c;证书的作用是用来证明公钥是否合法的。本文介绍的证书就是解决证书的可靠性的技术。 二…

从 0 到 1 ,手把手教你编写《消息队列》项目(Java实现) —— 核心类持久化存储

文章目录 一、持久化存储的方式与路径二、公共模块序列化 / 反序列化异常规定 三、持久化存储数据库数据管理文件数据管理读写规定新增 /删除规定内存中 Message 的规定存储规定代码编写 硬盘数据管理 一、持久化存储的方式与路径 交换机,队列,绑定关系,这些我们使用数据库来管…

【数据结构--八大排序】之希尔排序

&#x1f490; &#x1f338; &#x1f337; &#x1f340; &#x1f339; &#x1f33b; &#x1f33a; &#x1f341; &#x1f343; &#x1f342; &#x1f33f; &#x1f344;&#x1f35d; &#x1f35b; &#x1f364; &#x1f4c3;个人主页 &#xff1a;阿然成长日记 …

从零手搓一个【消息队列】实现虚拟主机的核心功能

文章目录 一、虚拟主机设计二、实现虚拟主机1, 创建 VirtualHost 类2, VirtualHost() 构造方法3, exchangeDeclare() 创建交换机4, exchageDelete() 删除交换机5, queueDeclare() 创建队列6, queueDelete() 删除队列7, queueBind() 创建绑定8, queueUnBind() 删除绑定9, basicP…

基于Java的高校办公室会议行政事务管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…

电气基础——电源、变压器、接触器、断路器、线缆

目录 1.电源 2.变压器 三项电和2相电的转换 3.接触器 4.断路器 5.线缆 1.电源 2.变压器 三项电和2相电的转换 三相电转为2相电 1.变压器 2.相位移转换器 3.电容器 两相电变不了三相电。但是两相电可以通过电容移相后带动三相电机 零线&#xff0c;地线N&#xff…

VD6283TX环境光传感器驱动开发(1)----获取ID

VD6283TX环境光传感器驱动开发----1.获取ID 概述视频教学样品申请源码下载模块参数IIC接线方式设备ID生成STM32CUBEMX串口配置 IIC配置串口重定向模块地址获取ID主函数结果演示 概述 环境光传感器是一种光电探测器&#xff0c;能够将光转换为电压或者电流&#xff0c;使用多光…

适合在校学生的云服务器有哪些?

随着云计算技术的发展&#xff0c;越来越多的学生开始使用云服务器来进行学习和实践。对于学生来说&#xff0c;选择一款便宜的云服务器不仅可以帮助他们降低成本&#xff0c;还可以提高学习和实践的效率。本文将介绍几款适合学生使用的便宜云服务器。 1、腾讯云学生服务器【点…

最新反编译小程序教程(支持分包一键反编译),反编译成功率高达99%

最新反编译小程序教程&#xff08;支持分包一键反编译&#xff09;&#xff0c;反编译成功率高达99% 优点&#xff1a; 1.支持多个分包以及主包一次性反编译&#xff1b; 2.使用wxappUnpacker无法进行解析的小程序包&#xff0c;一键反编译解析&#xff08;咱没有发现反编译失败…