news 2026/6/12 16:07:50

二分算法进阶

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
二分算法进阶

一、高考志愿

1、问题:现有 m 所学校,每所学校预计分数线是 a​。有 n 位学生,估分分别为 b。根据 n 位学生的估分情况,分别给每位学生推荐一所学校,要求学校的预计分数线和学生的估分相差最小(可高可低,毕竟是估分嘛),这个最小值为不满意度。求所有学生不满意度和的最小值。

2、输入格式:第一行读入两个整数 m, n。
第二行共有 m 个数,表示 m 个学校的预计录取分数。
第三行共有 n 个数,表示 n 个学生的估分成绩。

3、输出格式:输出一行,为最小的不满度之和。

4、解析思路:将分数线按升序排序,取中间值(中间的分数线)为临时的适合分数线,实际分数a若大于临时适合分数线,就看更高一点的学校的分数线,否则相反。若该学生的分数高于最高分数 线,则用分数减去分数线;若低于最低分数线,则用最低分数线减去分数;若处于中间某分数线附近,则根据绝对值最小的来取满意度

5、代码如下:

#include<bits/stdc++.h> using namespace std; int school[100001]; long long sum=0; int main() { int m,n; cin>>m>>n; for(int i=1;i<=m;i++) cin>>school[i]; sort(school+1,school+1+m); for(int i=0;i<n;i++) { int a,r=m,l=1,mid; cin >>a; while(l<r) { mid=(l+r)/2; if(a>=school[mid]) l=mid+1; else r=mid; } if(a<school[1]) { sum+=school[1]-a; } else if(l > m) { sum+=a - school[m]; } else { sum+=min(abs(school[l]-a),abs(school[l-1]-a)); } } printf("%lld",sum); return 0; }

二、木材加工

1、问题:木材厂有 n 根原木,现在想把这些木头切割成 k 段长度均为 l 的小段木头(木头有可能有剩余)。
当然,我们希望得到的小段木头越长越好,请求出 l 的最大值。
木头长度的单位是 cm,原木的长度都是正整数,我们要求切割得到的小段木头的长度也是正整数。
例如有两根原木长度分别为 11 和 21,要求切割成等长的 6 段,很明显能切割出来的小段木头长度最长为 5。

2、输入格式:第一行是两个正整数n和k ,分别表示原木的数量,需要得到的小段的数量。
接下来 n 行,每行一个正整数 L,表示一根原木的长度。

3、输出格式:仅一行,即 l 的最大值。
如果连 1cm 长的小段都切不出来,输出 0

4、解析思路:将长度按降序排序,长度不够1cm直接输出0。从中间长度开始锯木头,用count计数,看锯出来的木头数量是否达标,达标则增加锯的长度,没达标就按上一长度(当前的r)来算。

5、代码如下:

#include<bits/stdc++.h> using namespace std; long long n,k,L[100006],sum,count_; bool cmp(int a,int b) { return a>b; } int main() { scanf("%lld%lld",&n,&k); for(int i=1;i<=n;i++) { cin>>L[i]; sum+=L[i]; } sort(L+1,L+1+n,cmp); if(sum<k) printf("0"); else { int l=1,r=L[1]; while(l<=r) { int mid=(l+r)/2; count_=0; for (int i=1;i<=n;i++) { count_+=L[i]/mid; if(count_>k||count_<=k&&L[i]<mid) break; } if(count_>=k) l=mid+1; else r=mid-1; } cout<<r; } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 15:48:38

35、打印服务全解析:设置、故障排除与常见问题解答

打印服务全解析:设置、故障排除与常见问题解答 1. 打印通知设置 在设置打印通知时,可按以下步骤操作: - 打开“Set Notifications (Optional)”向导页面,有两种通知设置方式可供选择: - 邮件通知 :选中“Send Email Notification”复选框,输入一个或多个收件人和发…

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

LangFlow如何管理敏感信息?API密钥加密存储方案

LangFlow 如何安全处理 API 密钥&#xff1f;深入解析其敏感信息管理机制 在 AI 应用开发日益普及的今天&#xff0c;低代码平台正成为开发者快速构建智能工作流的核心工具。LangFlow 作为 LangChain 生态中最具代表性的可视化编排工具&#xff0c;凭借“拖拽即用”的交互体验&…

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

视频解说创作,从未如此简单

影视混剪工具演示还在为制作原创视频内容而苦恼吗&#xff1f;脚本写好了&#xff0c;素材也有了&#xff0c;却卡在了枯燥的后期处理上&#xff1f; 切片、合并、配音、混音… 每一个环节都像是技术壁垒&#xff0c;消耗着你本应用于创意构思的宝贵时间。 我们懂你。 所以&…

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

Multisim示波器使用在电路仿真中的核心要点

深入掌握Multisim示波器&#xff1a;从电路仿真到动态信号分析的实战指南你有没有遇到过这样的情况&#xff1f;在搭建一个放大电路时&#xff0c;理论计算明明没问题&#xff0c;但输出波形却严重失真&#xff1b;或者设计了一个滤波器&#xff0c;输入是1kHz正弦波&#xff0…

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

内核中延迟的工作delayed_work

对于周期性的任务&#xff0c;除了定时器以外&#xff0c;在Linux内核中还可以利用一套封装得很好的快捷机制&#xff0c;其本质是利用工作队列和定时器实现&#xff0c;这套快捷机制就是delayed_work. schedule_delayed_work的作用为在指定延时后将任务&#xff0c;放到工作队…

作者头像 李华