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

2025 北京市大学生程序设计竞赛暨“小米杯”全国邀请赛

E 计算几何 坐标系转换 二分答案题意在一条线上找一个点到所给点的最大距离最短最大的最小考虑对最大距离进行二分答案check(dis)判断dis能不能≥\geq≥线上某个点到每个点的距离坐标变换后设线上合理的某个点是(xc,0)(x_c,0)(xc​,0)(x−xc)2y2≤dis2(x-x_c)^2y^2\leq dis^2(x−xc​)2y2≤dis2xcx_cxc​的范围是[xc−y2−dis2,xcy2−dis2][x_c-\sqrt{y^2-dis^2},x_c\sqrt{y^2-dis^2}][xc​−y2−dis2​,xc​y2−dis2​]交集不是空集即合理constdoublePIacos(-1);constlonglongmod998244353,inf1e9;doublea,b,c;// double dis(pdd p){// return abs(a*p.xxb*p.yyc)/sqrt(a*ab*b);// }voidsolve(){intn;cinn;vectorpddpos(n1);forr(i,1,n)cinpos[i].xxpos[i].yy;cinabc;doublemagsqrt(a*ab*b);doublethetaacos(abs(b/mag));if(-a*b0)theta-theta;// coutthetaendl;//转换坐标系forr(i,1,n){doublenxpos[i].xx*cos(theta)pos[i].yy*sin(theta);doublenypos[i].yy*cos(theta)-pos[i].xx*sin(theta)(b0?-c/a:c*cos(theta)/b);// double nypos[i].yy*cos(theta)-pos[i].xx*sin(theta);pos[i].xxnx,pos[i].yyny;// coutnx nyendl;}// 二分答案 枚举最后的距离答案autocheck[](doubledis)-bool{doublelmx-1e18,rmn1e18;forr(i,1,n){if(dis-abs(pos[i].yy)-1e-8)returnfalse;doubledsqrt(dis*dis-pos[i].yy*pos[i].yy);lmxmax(lmx,pos[i].xx-d),rmnmin(rmn,pos[i].xxd);if(rmn-lmx-1e-8)returnfalse;}returntrue;};doublel0,r1e7;while(r-l1e-8){doublemid(lr)/2;if(check(mid)){rmid;}elselmid;}// coutans;coutfixedsetprecision(8)rendl;}G dp一看这个题就感觉是dp本次选哪一个之前的路径会影响到未来但是受限于水平不会实现…动态规划成立的前提一旦当前阶段的状态确定未来的演变与过去无关当前状态已包含所有对未来决策有用的信息每次更新的是以当前萤火虫作为末尾的状态每次从上一个记录的w的质因数p和颜色cw的质因数p和颜色cw的质因数p和颜色c转移过来dp[p][c]dp[p][c]dp[p][c]但是和本次颜色不同的颜色有很多一一判断会超时为了让最后答案链最长需要关注前面最长的链但是最长链的末尾颜色和本次颜色相同的话这个链就断了末尾颜色与最长链不同的次长链也会是最优解的一个选择本次更新后不是选之前的最长链就是次长链。设计color[p][0最长/1次长],dp[p][0最长/1次长]color[p][0最长/1次长],dp[p][0最长/1次长]color[p][0最长/1次长],dp[p][0最长/1次长]或者直接合二为一dp[p][0最长/1次长][0记录的颜色/1链的长度]]dp[p][0最长/1次长][0记录的颜色/1链的长度]]dp[p][0最长/1次长][0记录的颜色/1链的长度]]constintN5e5,M1e91;constdoublePIacos(-1);constlonglongmod998244353,inf1e9;vectorintprime;intminp[N10];// 每个数的最小质因数voidfind_p(){minp[1]1;forr(i,2,N){if(!minp[i]){minp[i]i;prime.push_back(i);}for(autop:prime){if(i*pN)break;minp[i*p]p;if(pminp[i])break;}}}arrayarrayint,2,2f[N10];voidsolve(){find_p();intn;cinn;vectorintw(n1),c(n1);forr(i,1,n)cinw[i];forr(i,1,n)cinc[i];f[1][0][0]c[1],f[1][0][1]1;f[1][1][0]c[1],f[1][1][1]1;forr(i,1,n){//分解质因数vectorintfactor;while(w[i]1){intxminp[w[i]];while(w[i]%x0)w[i]/x;factor.push_back(x);}// 找本次最优intres1;for(autop:factor){if(c[i]!f[p][0][0])resmax(res,f[p][0][1]1);if(c[i]!f[p][1][0])resmax(res,f[p][1][1]1);}//记录最优值for(autop:factor){/* 这里正解代码写的是 if (c[i] ! f[x][0][0]) { if (res f[x][0][1]) { f[x][1] f[x][0]; f[x][0] {c[i], res}; } else if (res f[x][1][1]) { f[x][1] {c[i], res}; } } else { if (res f[x][0][1]) { f[x][0] {c[i], res}; } } assert(f[x][0][0] ! f[x][1][0]); *//* 之前的错误解法 if(resf[p][0][1]){ f[p][1]{c[i],res}; f[p][0]{c[i],res};//最大次大都成一个颜色了 }else if(resf[p][1][1]){ f[p][1]{c[i],res}; } 会wa在 7 2 5 4 3 6 3 5 6 9 7 7 7 2 8 *///需要保证最大次大的颜色不同if(c[i]!f[p][0][0]){//颜色不同if(resf[p][0][1]){//放到最大的位置f[p][1]f[p][0];f[p][0]{c[i],res};}elseif(resf[p][1][1]){//放到次大的位置f[p][1]{c[i],res};}}else{//颜色相同if(resf[p][0][1]){f[p][0][1]res;//直接刷新}}}}intans1;for(autop:prime){ansmax(ans,f[p][0][1]);}coutansendl;}

相关文章:

2025 北京市大学生程序设计竞赛暨“小米杯”全国邀请赛

E 计算几何 坐标系转换 二分答案题意:在一条线上找一个点到所给点的最大距离最短 最大的最小,考虑对最大距离进行二分答案,check(dis)判断dis能不能≥\geq≥线上某个点到每个点的距离 坐标变换后,设线上合理的某个点是(xc,0)(x_c,…...

C++面试必考:指针与引用区别详解

2025年C面试题全面解析与答案指南 一、C基础核心概念 1.1 基础语法与特性 面试考点核心要点考察频率指针与引用区别、使用场景、内存管理⭐⭐⭐⭐⭐const关键字常量定义、函数修饰、成员函数⭐⭐⭐⭐static关键字静态变量、静态函数、静态成员⭐⭐⭐⭐内存管理new/delete、m…...

遇到D3DCompiler_47.dll缺失找不到如何解决? 免费下载方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…...

TensorFlow eager模式超流畅

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 TensorFlow Eager模式:解锁AI开发的流畅新境界目录TensorFlow Eager模式:解锁AI开发的流畅新境界 引言&a…...

CSS中盒模型的边框属性

margin:外边距 如果想要让A元素和B元素有一点距离可以设置外边距 padding:内边距 div中想写文字 不想让它紧挨着边框可以设置内边距使用height:100%时,父元素高度是0,子元素100%不会生效,所以高度默认由元素内容撑起 如果div中不写文字 那么即…...

2026毕设救星!手把手教你用AI工具,告别论文焦虑

高效搞定论文,你的时间应该花在研究,而不是繁琐的格式与重复劳动上。 随着2026年毕业季的临近,无数本科生即将面对毕业论文这座“大山”——从选题、查文献、写初稿、做图表、调格式,到最后的降重和答辩PPT,每一个环节…...

徐州千合瑜伽

徐州千合瑜伽(铜山万达店)千合瑜伽,瑜伽、普拉提、产后修复、体态矫正适合人群:零基础新手 | 产后妈妈 | 肩颈腰背不适者 | 减脂塑形人群 | 压力大需放松者老师情况:✅ 所有老师持证上岗(全美瑜伽联盟认证/…...

2024全新版 操作系统入门与实践-参透技术本质(完结)

https://www.bilibili.com/video/BV1sJwszeEFt/?vd_sourcee494c817aecfade3d91bd7b5c9c7d575 穿越周期的红利:为何操作系统是性价比最高的技术投资 在程序员的职业生涯中,最残酷的真相莫过于:你所掌握的大多数技能,都会随着时间贬…...

【WIN开发】02进程间通信方式汇总

一、什么是进程间通信? 进程间通信(IPC):让不同进程之间交换数据、互相通知的技术。 就像两个独立的办公室要互相传文件,可以用: 打电话(Socket) 递纸条(剪切板) 传文件服务器(邮槽) 内部通道(管道) 喊一嗓子(消息) 二、6种通信方式简介 1. Socket编程(网络…...

双螺杆挤出机用减速机分配箱装配图ks36

双螺杆挤出机作为高分子材料加工领域的核心设备,其运行稳定性直接取决于关键部件的协同效率。分配箱作为连接驱动电机与螺杆的核心传动单元,承担着动力分配、扭矩传递及转速调节的关键职能。KS36型分配箱通过精密的齿轮啮合系统与箱体结构,将…...

细读经典: ZeRO

论文链接:https://arxiv.org/pdf/1910.02054 训练并行的几种方式: 1. Pipeline Parallelism (PP) 2. Model Parallelism (MP) 3. Data Parallelism So, how can we overcome the limitations of existing solutions and train large models more eff…...

设备预测性维护服务商选择的关键维度

在工业4.0和智能制造背景下,预测性维护(PdM)成为企业降本增效的核心手段。选择优质服务商需从技术实力、行业经验、系统兼容性、数据安全及售后服务等多维度综合评估。技术架构与算法能力服务商需具备成熟的物联网(IoT&#xff09…...

一套全方位零售数字化经营系统:技术解析与业务赋能

摘要:本文详细介绍了一套集零售、订货、门店、采购、仓储、客户、财务、销售、营销及数据管理等功能于一体的综合性数字化经营系统。该系统采用 PHP8.2 MYSQL8.0 WEBMAN 作为核心框架技术,前端基于 uniapp 开发,具备高性能、跨平台等优势。…...

linux——目录及文件操作

linux目录及文件操作常用的linux指令cd文件夹名字: 访问某个文件夹ls:显示当前所在目录的文件touch文件名:创建文件rm文件名:删除文件mkdir目录名:创建目录rm -rf 目录名:删除目录TAB键:补全sudo 命令&am…...

【Python数据分析论文模版】基于Python的淘宝网手机销售数据分析与可视化

基于Python的淘宝网手机销售数据分析与可视化 摘 要 如今科技飞速发展,我国线上购物不断在拉动提高国民消费水平。在大环境下,人们对于以手机为代表的智能产品需求不断攀升,手机的更新换代越加频繁,如何选择一款适合自己的手机也…...

跨端融合,精准匹配:专业人才招聘管理App的技术创新与行业实践

摘要:本文聚焦于一款基于uni-app(Vue 2)开发的工程施工与设备作业领域专业人才招聘管理App,深入剖析其技术架构、核心功能及独特优势。通过多端统一开发、业务场景深度适配、轻量化部署等创新点,该平台有效解决了工程用…...

古装微短剧《嘉庆君游台湾》开机 霍政谚全力以赴演绎永琰

3月13日,由北京市人民政府台湾事务办公室官方新媒体平台“京彩台湾”出品,北京博羽齐文化传媒有限公司承制,由霍政谚、丁梓航、余玥、麦片(吴羽朔)等主演的古装微短剧《嘉庆君游台湾》在福建省泉州市百崎短剧园举行开机…...

智慧养殖鱼类病害的自动识别与分类 助水产养殖从业者及时诊断鱼病 鱼类疾病识别数据集 鱼类养殖检测数据集第10561期

一个用于鱼类病害识别的目标检测数据集,助力水产养殖智能化监测 一个用于鱼类病害识别的目标检测数据集,助力水产养殖智能化监测。数据集核心信息项目内容类别数量及中文名称7类:细菌性疾病-气单胞菌病、细菌性鳃病、细菌性红病、真菌病-水霉…...

基于Spring Boot的乡村信息管理系统设计与实践

第一章:系统设计目标与需求拆解 在乡村振兴战略推进与数字化治理深化的背景下,基于Spring Boot的乡村信息管理系统,核心目标是构建乡村信息“一站式”管理平台,解决传统乡村管理中数据分散、沟通滞后、服务低效等问题。从需求层面…...

3月16日直播丨面向新一代硬件,CANN技术架构的变与不变

B站/微信视频号搜索【昇腾CANN】观看直播,期待你的观看~ 点击预约直播:https://www.bilibili.com/opus/1179251767286693911?spm_id_from333.1387.0.0...

《Azul报告:62%的Java开发者已在写AI代码,这5个Java+AI实战场景你必须会》

文章目录写在前面:Java正在悄悄"收割"AI战场场景一:用大模型给客服系统装个"脑子"(Spring AI实战)啥情况需要这个?技术方案:Spring AI 函数调用核心就三步:第一步&#xf…...

制造业信息化系统开发工程师 - 学习资料汇总

制造业信息化系统开发工程师 - 学习资料汇总 一、MES(制造执行系统)学习资料 1.1 MES核心功能模块详解 根据工信部《制造执行系统(MES)规范》,合规MES必须具备10大核心功能: 📌 模块一:生产计划与排程 …...

PFM和FCCM的区别是什么?

PFM(脉冲频率调制)与 FCCM(强制连续导通模式)是 DC-DC 开关电源中两种核心工作模式,核心区别在于:PFM 是变频、轻载高效、纹波 / EMI 较差;FCCM 是定频、强制电流连续、轻载低效但纹波 / EMI / …...

基于SpringBoot的运动服装销售系统设计与实现

一、系统开发背景与意义 随着全民健身意识的普及和体育产业的快速发展,运动服装市场需求持续增长。但当前运动服装销售领域存在诸多痛点:线上端难以精准的产品分类与场景化推荐,选购效率低;商家库存管理粗放,易出现断码…...

基于嵌入式的数据库SQLite

轻量级的嵌入式数据库sqlite 1 SQLite3的安装 采用在线安装,在linux命令行:sudo apt install sqlite3 在命令行输入sqlite3,显示如下界面则表示安装成功。 2 SQLite3的基本指令 系统命令 .quit 退出数据库 .help 数据…...

知识点总结三

一、Windows 系统基础认知操作系统核心:是管理计算机软硬件资源的核心程序,所有软件需在其支持下运行。主流系统对比:Windows 图形友好、兼容性强,适用于企业服务器和个人设备;Linux 开源稳定,多用于服务器…...

一次性熔断保险丝 vs PPTC 选型参数全解析(硬件工程师必备)

在电路过流保护设计中,一次性熔断保险丝(Fuse) 与 PPTC 自恢复保险丝 是最常用的两类器件。本文系统梳理两者核心选型参数、选型逻辑与应用差异,附选型步骤与实战避坑,帮你快速搞定电路保护设计。一、一次性熔断保险丝…...

事件驱动在AI原生应用领域的应用实践分享

事件驱动在AI原生应用领域的应用实践分享 关键词 事件驱动架构(EDA)、AI原生应用、事件流处理、持续学习系统、动态决策引擎、因果事件建模、云原生事件平台 摘要 本报告系统解析事件驱动架构(EDA)在AI原生应用中的创新实践&#…...

STM32矩阵键盘驱动实战解析

矩阵键盘驱动程序实现以下是一个基于STM32标准库的4x4矩阵键盘驱动程序实现,使用PA4-PA7作为行线,PC0-PC3作为列线。硬件连接行线(输出): PA4-PA7列线(输入): PC0-PC3上拉电阻: 列线需要外部上拉电阻(4.7kΩ-10kΩ)初始化函数void KeyPad_Init(void) {GP…...

褪去故事滤镜:重建精品可可的“结构语言”

卷首语:在这个充满营销话术的时代,我们似乎越来越习惯用“动人的故事”去消费一个产品。但作为一个对真实风味保持怀疑与严谨态度的品鉴者,我们深知:故事,永远无法替代判断。今天,让我们褪去滤镜。从亚洲产…...