news 2026/6/10 1:11:38

链式投票|流向贪心

作者头像

张小明

前端开发工程师

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/10 17:02:28

传统开发vsAI辅助:IDM模块开发效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个高效的IDM集成模块&#xff0c;用于自动化用户生命周期管理。模块需要支持SCIM协议&#xff0c;提供用户CRUD操作&#xff0c;与HR系统集成实现自动化用户配置。使用Node.j…

作者头像 李华
网站建设 2026/6/9 10:04:14

VLA:AI如何革新视觉语言理解开发

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 使用快马平台构建一个基于VLA技术的图像描述生成应用。输入一张图片&#xff0c;AI自动生成详细的文字描述。要求支持多模态输入&#xff08;图片文本&#xff09;&#xff0c;使用…

作者头像 李华
网站建设 2026/6/5 6:44:22

1Panel高效管理:多服务器批量操作实战指南

1Panel高效管理&#xff1a;多服务器批量操作实战指南 【免费下载链接】1Panel 项目地址: https://gitcode.com/GitHub_Trending/1p/1Panel 你是否曾经为管理多台服务器而感到力不从心&#xff1f;每次更新都要逐台登录、重复操作&#xff0c;不仅耗时耗力&#xff0c;…

作者头像 李华
网站建设 2026/6/10 13:53:38

WuWa-Mod模组终极指南:彻底改变《鸣潮》游戏体验

想要在《鸣潮》中体验前所未有的游戏乐趣吗&#xff1f;WuWa-Mod模组为你带来超过15种强大功能&#xff0c;从无限技能到智能拾取&#xff0c;让每一场冒险都充满惊喜。本文将为你提供完整的安装和使用方案。 【免费下载链接】wuwa-mod Wuthering Waves pak mods 项目地址: h…

作者头像 李华
网站建设 2026/6/10 17:13:26

发那科机器人CRM52A、CRM52B接口配置终极指南:快速上手与实战应用

发那科机器人CRM52A、CRM52B接口配置终极指南&#xff1a;快速上手与实战应用 【免费下载链接】发那科机器人CRM52ACRM52B接口说明 发那科机器人CRM52A、CRM52B接口说明 项目地址: https://gitcode.com/Open-source-documentation-tutorial/71d54 想要立即掌握发那科机器…

作者头像 李华
网站建设 2026/6/10 6:42:31

鸿蒙 Electron:跨端开发的极致融合,从原生能力调用到工程化部署

在跨端开发领域&#xff0c;Electron 凭借前端技术栈的低门槛和跨桌面平台的优势&#xff0c;成为桌面应用开发的主流选择&#xff1b;而鸿蒙&#xff08;HarmonyOS&#xff09;以 “分布式全场景” 为核心&#xff0c;构建了覆盖手机、平板、智慧屏、桌面设备的生态体系。将两…

作者头像 李华