CF每日4题

news2025/4/26 2:19:51

1500左右的做到还是有点吃力

2093E 1500 二分答案

题意:给定一个长度为 n 的数组,现在要把它切成 k 份,求每一份最小的MEX中的最大值。

  • 就是找最大值,但是这个值是所有段最小的值
  • 采用二分答案,二分这个值,check这个值是否是分成k段最小的

二分查找扫盲
因为尽量找最大值 向右查找 使用上文章中模板二

while (l < r)
{
      int mid = l + r + 1 >> 1;	//(l+r+1)/2
      if (check(mid))  l = mid;
      else r = mid - 1;
}

答案在l中

const int N=2e5+10;
int n,k;
int a[N];
bool check(int mx){
    set<int>vis;
    int cnt=0;
    forr(i,1,n){
        if(a[i]<mx)vis.insert(a[i]);
        if(vis.size()==mx){
            cnt++;
            vis.clear();
        }
    }
    return cnt>=k;//分的组数大,说明mx较小,选择右区间
}
void solve(){
    cin>>n>>k;
    forr(i,1,n){
        cin>>a[i];
    }
    int l=0,r=n;
    while (l<r)
    {
        int mid=(l+r+1)>>1;
        if(check(mid)){
            l=mid;
        }else r=mid-1;
    }
    cout<<l<<endl;
}

2093D 1400 分治

参考文章

  • 题意:正方形格子边长 2 n 2^n 2n,从大到小按 3 1 ^1_3 31 2 4 ^4_2 24的形式填格子
  • 对每个大格子分成四份进行处理(每条边进行分治) 维护每份格子的左上角坐标,区间值
    在这里插入图片描述
const int N=60;
int tp[N+3];
void q1(int x,int y,int len,int mn,int mx){
    if(len==1)return cout<<mn<<endl,void();
    int rg=mx-mn+1;//方块的区间
    if(x<=len/2&&y<=len/2){//1
        q1(x,y,len/2,mn,mn+rg/4-1);
    }
    if(x>len/2&&y>len/2){//2
        q1(x-len/2,y-len/2,len/2,mn+rg/4,mn+rg/2-1);
    }
    if(x>len/2&&y<=len/2){//3
        q1(x-len/2,y,len/2,mn+rg/2,mn+rg/4*3-1);
    }
    if(x<=len/2&&y>len/2){//4
        q1(x,y-len/2,len/2,mn+rg/4*3,mx);
    }
}
void q2(int x,int y,int d,int len,int mn,int mx){
    // cout<<x<<' '<<y<<' '<<mn<<' '<<mx<<endl;
    if(len==1)return cout<<x<<' '<<y<<endl,void();
    int rg=mx-mn+1;//不用mx/4确定区间  使用最大值最小值距离去规定区间
    if(d<=mn+rg/4-1){//1  
        q2(x,y,d,len/2,mn,mn+rg/4-1);
    }else if(d<=mn+rg/2-1){//2
        q2(x+len/2,y+len/2,d,len/2,mn+rg/4,mn+rg/2-1);
    }else if(d<=mn+rg/4*3-1){//3
        q2(x+len/2,y,d,len/2,mn+rg/2,mn+rg/4*3-1);
    }else if(d<=mx){//4
        q2(x,y+len/2,d,len/2,mn+rg/4*3,mx);
    }
}
void solve(){
    int n,q;cin>>n>>q;
    forr(i,1,q){
        char c1,c2;
        cin>>c1>>c2;
        if(c1=='-'){
            int x,y;
            cin>>x>>y;
            q1(x,y,tp[n],1,tp[n*2]);
        }else {
            int d;cin>>d;
            q2(1,1,d,tp[n],1,tp[2*n]);
        }
    }
}
signed main()
{
    ios::sync_with_stdio(false), std::cin.tie(nullptr), std::cout.tie(nullptr);
    int _ ;
    _ = 1;
    tp[0]=1;
    forr(i,1,N){
        tp[i]=tp[i-1]*2;
        // tp[i]=(1<<i);
        cout<<tp[i]<<endl;
    }
    cin>>_;
    while (_--)
    {
        solve();
    }
    return 0;
}

2092C 1200 思维 贪心

  • 选两个数 a , b a,b a,b,一奇一偶,一个+1一个-1,最后两数仍是一奇一偶,可以重复操作直至 a + b , 0 a+b,0 a+b,0 a + b − 1 , 1 a+b-1,1 a+b1,1
  • 奇+偶=奇 最后答案一定是个奇数,对原数列分奇偶
  • 答案最优情况
    • 所有偶数都放入一个奇数中
    • 其他的奇数化成 a + b − 1 , 1 a+b-1,1 a+b1,1,放到偶数中,加入那个最大的奇数
void solve(){
    int n,ans=0,fg=0;
    cin>>n;
    vector<int>o,e;
    forr(i,1,n){
        int a;cin>>a;
        if(a&1)o.push_back(a);
        else e.push_back(a);
    }
    sort(o.begin(),o.end());
    sort(e.begin(),e.end());
    int lo=o.size(),le=e.size();

    if(lo&&le){
        for(auto i:e)ans+=i;    
        forr(i,0,lo-2){
            ans+=o[i]-1;
        }
        ans+=o[lo-1];
    }else if(!lo){
        ans=e[le-1];
    }else if(!le){
        ans=o[lo-1];
    }
    
    cout<<ans<<endl;
}

2091D 1200 水 模拟

void solve(){
    int n,m,k;cin>>n>>m>>k;
    int a=(k+n-1)/n;//每行最大桌子数
    int ad=max(2*a-1-m,0ll);//少的空格数
    int cnt=a-ad;//段数
    int ans=(a+cnt-1)/cnt;
    // cout<<a<<' '<<ad<<' ';
    cout<<ans<<endl;
}

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

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

相关文章

基于 Spring Boot 瑞吉外卖系统开发(七)

基于 Spring Boot 瑞吉外卖系统开发&#xff08;七&#xff09; 新增菜品页面 菜品管理页面提供了一个“新增菜品”按钮&#xff0c;单击该按钮时&#xff0c;会打开新增菜品页面。 菜品分类列表 首先要获取分类列表数据。 请求路径/category/list&#xff0c;请求方法GE…

二项式分布html实验

二项式分布html实验 本文将带你一步步搭建一个纯前端的二项分布 Monte-Carlo 模拟器。 只要一个 HTML 文件&#xff0c;打开就能运行&#xff1a; 动态输入试验次数 n、成功概率 p 与重复次数 m点击按钮立刻得到「模拟频数 vs 理论频数」柱状图随着 m 增大&#xff0c;两组柱状…

大模型如何作为reranker?

大模型如何作为reranker&#xff1f; 作者&#xff1a;爱工作的小小酥 原文地址&#xff1a;https://zhuanlan.zhihu.com/p/31805674335 只为了感动自己而去做一些事情纯属浪费时间。 ————爱工作的小小酥 引言 用于检索的模型中&#xff0c;我们最熟悉的就是单塔和双塔了&…

发放优惠券

文章目录 概要整体架构流程技术细节小结 概要 发放优惠券 处于暂停状态&#xff0c;或者待发放状态的优惠券&#xff0c;在优惠券列表中才会出现发放按钮&#xff0c;可以被发放&#xff1a; 需求分析以及接口设计 需要我们选择发放方式&#xff0c;使用期限。 发放方式分…

试完5个AI海报工具后,我投了秒出设计一票!

随着AI技术的不断发展&#xff0c;越来越多的AI生成工具进入了设计领域&#xff0c;海报生成工具成为了其中的重要一员。今天&#xff0c;我们将为大家介绍三款热门的AI海报生成工具&#xff0c;并进行对比分析&#xff0c;帮助大家选择最适合的工具。 1. 秒出设计&#xff1a;…

PH热榜 | 2025-04-25

1. LambdaTest Accessibility Testing Suite 标语&#xff1a;轻松点击&#xff0c;确保网站的包容性和合规性。 介绍&#xff1a;LambdaTest 的可访问性测试工具可以自动识别你的网站和网络应用中是否符合 WCAG&#xff08;网页内容无障碍指南&#xff09;标准。你可以设置定…

模方ModelFun是什么?如何安装?

摘要&#xff1a;本文主要介绍模方ModelFun的软件简介、特性、安装环境配置、插件及软件安装。 1.软件简介 模方是一款实景三维模型的场景修饰与单体化建模工具&#xff0c;是建模的后处理软件&#xff0c;包括网格模型编辑和单体化建模两大模块。 场景修饰模块可以对 OBJ、OSG…

[AI Workflow] 基于多语种知识库的 Dify Workflow 构建与优化实践

在实际应用中,基于用户提供的资料快速构建高质量的知识库,并以此背景精准回答专业问题,是提升人工智能系统实用性的重要方向。然而,在跨语种环境下(如中、日、英混合资料与提问),传统的知识检索和回答生成流程往往面临匹配不准确、信息检索不全面的问题。 本文将介绍一种…

Pycharm(十六)面向对象进阶

一、继承 概述&#xff1a; 实际开发中&#xff0c;我们发现很多类中的步分内容是相似的&#xff0c;或者相同的&#xff0c;每次写很麻烦&#xff0c;针对这种情况&#xff0c; 我们可以把这些相似&#xff08;相同的&#xff09;部分抽取出来&#xff0c;单独地放到1个类中&…

WebGL图形编程实战【4】:光影交织 × 逐片元光照与渲染技巧

现实世界中的物体被光线照射时&#xff0c;会反射一部分光。只有当反射光线进人你的眼睛时&#xff0c;你才能够看到物体并辩认出它的颜色。 光源类型 平行光&#xff08;Directional Light&#xff09;&#xff1a;光线是相互平行的&#xff0c;平行光具有方向。平行光可以看…

Java高频面试之并发编程-07

hello啊&#xff0c;各位观众姥爷们&#xff01;&#xff01;&#xff01;本baby今天来报道了&#xff01;哈哈哈哈哈嗝&#x1f436; 面试官&#xff1a;线程之间有哪些通信方式&#xff1f; 在 Java 多线程编程中&#xff0c;线程间通信&#xff08;Inter-Thread Communica…

.NET代码保护混淆和软件许可系统——Eziriz .NET Reactor 7

.NET代码保护混淆和软件许可系统——Eziriz .NET Reactor 7 1、简介2、功能特点3、知识产权保护功能4、强大的许可系统5、软件开发工具包6、部署方式7、下载 1、简介 .NET Reactor是用于为.NET Framework编写的软件的功能强大的代码保护和软件许可系统&#xff0c;并且支持生成…

【现代深度学习技术】循环神经网络06:循环神经网络的简洁实现

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上&#xff0c;结合当代大数据和大算力的发展而发展出来的。深度学习最重…

【办公类-89-02】20250424会议记录模版WORD自动添加空格补全下划线

背景需求 4月23日听了一个MJB的征文培训&#xff0c;需要写会议记录 把资料黏贴到模版后&#xff0c;发现每行需要有画满下划线 原来做这套资料&#xff0c;就是手动按空格到一行末&#xff0c;有空格才会出现下划线&#xff0c;也就是要按很多的空格&#xff08;凑满一行&…

解释器模式:自定义语言解析与执行的设计模式

解释器模式&#xff1a;自定义语言解析与执行的设计模式 一、模式核心&#xff1a;定义语言文法并实现解释器处理句子 在软件开发中&#xff0c;当需要处理特定领域的语言&#xff08;如数学表达式、正则表达式、自定义配置语言&#xff09;时&#xff0c;可以通过解释器模式…

AI催生DLP新战场 | 天空卫士连续6年入选Gartner 全球数据防泄漏(DLP)市场指南

“管理数据外泄风险仍然是企业的重大挑战之一&#xff0c;客户处出于各种因素寻求DLP。最近&#xff0c;一些组织对使用DLP控制机器对敏感信息的访问表现出很大兴趣。 随着生成式人工智能&#xff08;GenAI&#xff09;的运用和数据的不断扩散&#xff0c;数据外泄的问题变得更…

Adobe After Effects的插件--------Optical Flares之Lens Objects参数

Lens Objects,即【镜头对象】。 通用设置 全局参数发光多光圈光圈条纹微光反射钉球闪光圆环箍焦散镜头球缩放✔✔✔✔✔✔✔✔✔✔✔✔✔缩放偏移✔长宽比✔✔✔✔✔✔✔✔✔✔✔✔✔混合模式✔颜色✔全局种子✔亮度✔✔✔✔✔✔✔✔✔✔✔✔拉伸✔✔✔✔✔✔✔✔✔✔✔✔距离…

【问题】解决docker的方式安装n8n,找不到docker.n8n.io/n8nio/n8n:latest镜像的问题

问题概览 用docker方式安装n8n&#xff0c;遇到错误&#xff0c;安装不了的问题&#xff1a; Unable to find image docker.n8n.io/n8nio/n8n:latest locally docker: Error response from daemon: Get "https://registry-1.docker.io/v2/": net/http: request can…

系统与网络安全------弹性交换网络(1)

资料整理于网络资料、书本资料、AI&#xff0c;仅供个人学习参考。 Trunk原理与配置 Trunk原理概述 Trunk&#xff08;虚拟局域网中继技术&#xff09;是指能让连接在不同交换机上的相同VLAN中的主机互通。 VLAN内通信 实现跨交换的同VLAN通信&#xff0c;通过Trunk链路&am…