news 2026/6/12 22:15:46

链式投票|流向贪心

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
链式投票|流向贪心

lc

lc797

先凑总和非负,找唯一负数位置

从近到远取两边正数补负数,累计移动步数得最小操作数

class Solution {
public:
long long minMoves(vector<int>& balance) {
long long total = 0;
int neg_idx = -1;
for (int i = 0; i < balance.size(); i++) {
int x = balance[i];
total += x;
if (x < 0) {
neg_idx = i;
}
}

if (total < 0) { // 总和必须非负
return -1;
}
if (neg_idx < 0) { // 没有负数,无需操作
return 0;
}

int n = balance.size();
int need = -balance[neg_idx];
long long ans = 0;
for (int dis = 1; ; dis++) { // 把与 neg_idx 相距 dis 的数移到 neg_idx
int s = balance[(neg_idx - dis + n) % n] + balance[(neg_idx + dis) % n];
if (s >= need) {
ans += 1LL * need * dis; // need 个 1 移动 dis 次
return ans;
}
ans += 1LL * s * dis; // s 个 1 移动 dis 次
need -= s;
}
}
};

lc277

1.找候选人

2.check候选人(3种situation)

/* The knows API is defined for you.
bool knows(int a, int b); */

class Solution
{
public:
int findCelebrity(int n)
{
int candidate = 0; //候选人
for (int x = 1; x < n; x ++)
{
if ( knows(candidate, x) == true ) //若候选人认识别人,就不可能是名人。名人不认识其他人
{
candidate = x; //所有人,一定认识名人
//////小于x的那些,要么是因为 (1)被人不知,if被人知,就抢到了candidate了
//////(2) 要么是因为认识了别人,就放弃了candidate
}
}

for (int x = 0 ; x < n; x ++)
{
if (candidate == x) //名人不认识其他人,但是认识自己
continue;
if ( knows(candidate, x) == true)
return -1; //名人不应该认识 anyone
if (knows(x, candidate) == false)
return -1; //anyone 认识名人
}

return candidate;
}
};

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 11:14:30

TockOS基于能力的安全架构深度解析

TockOS基于能力的安全架构深度解析 【免费下载链接】tock 项目地址: https://gitcode.com/gh_mirrors/toc/tock 在嵌入式系统开发中&#xff0c;内存安全和系统隔离一直是核心挑战。TockOS通过Rust语言特性和创新的能力(capability)机制&#xff0c;为嵌入式设备提供了…

作者头像 李华
网站建设 2026/6/10 12:11:39

如何快速优化Windows系统:3分钟解决卡顿问题

如何快速优化Windows系统&#xff1a;3分钟解决卡顿问题 【免费下载链接】ExplorerPatcher 提升Windows操作系统下的工作环境 项目地址: https://gitcode.com/GitHub_Trending/ex/ExplorerPatcher Windows系统优化是每个用户都应该掌握的基本技能&#xff0c;它能让你的…

作者头像 李华
网站建设 2026/6/12 22:40:05

Qwen Agent实战:从零搭建智能客服系统

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个智能客服系统&#xff0c;利用Qwen Agent处理用户咨询。系统需要支持&#xff1a;1. 自然语言理解识别用户意图 2. 对接企业知识库自动回复 3. 多轮对话上下文记忆 4. 未解…

作者头像 李华
网站建设 2026/6/13 16:52:05

5分钟原型:快速验证Gradle插件解决方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Gradle插件问题快速验证工具&#xff0c;允许用户&#xff1a;1. 快速创建测试项目&#xff1b;2. 注入特定的插件配置问题&#xff1b;3. 模拟org.gradle.api.internal.pl…

作者头像 李华
网站建设 2026/6/12 11:23:55

OrcaSlicer依赖库编译实战:从源码构建到性能优化全解析

OrcaSlicer依赖库编译实战&#xff1a;从源码构建到性能优化全解析 【免费下载链接】OrcaSlicer G-code generator for 3D printers (Bambu, Prusa, Voron, VzBot, RatRig, Creality, etc.) 项目地址: https://gitcode.com/GitHub_Trending/orc/OrcaSlicer 问题场景&…

作者头像 李华
网站建设 2026/6/10 19:48:02

3步掌握Horovod Process Sets:千亿模型并行训练实战指南

3步掌握Horovod Process Sets&#xff1a;千亿模型并行训练实战指南 【免费下载链接】horovod Distributed training framework for TensorFlow, Keras, PyTorch, and Apache MXNet. 项目地址: https://gitcode.com/gh_mirrors/ho/horovod 还在为超大模型训练时的显存不…

作者头像 李华