2023牛客寒假算法基础集训营5

news2025/1/14 18:17:47

(0条未读通知) 【题解】2023牛客寒假算法基础集训营5_ICPC/CCPC/NOIP/NOI刷题训练题单_牛客竞赛OJ (nowcoder.com)

A-小沙の好客

 下面是错误代码,我刚开始看到这题,觉得很简单阿,做了才知道,会超时,所以不能单纯的去做,而是加上一些思维。

#include<bits/stdc++.h>
using namespace std;
bool cmp(int x,int y){
    return x>y;
}
int main(){
    int n,q,k,x,i,a[100005],y;
    cin>>n>>q;
    for(i=0;i<n;i++)cin>>a[i];
    sort(a,a+n,cmp);
    while(q--){
        y=0;
        cin>>k>>x;
        for(i=0;i<n;i++){
            if(k==0)break;
            if(a[i]<=x){y+=a[i];k--;}
        }
        cout<<y<<endl;
    }
    return 0;
}

//下面给出正确代码

//参考了题解讨论的博主代码

//核心是前缀和以及二分,upper_bound( begin,end,num):从数组的begin位置到end-1位置二分查找第一个大于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。

关于lower_bound( )和upper_bound( )的常见用法_brandong的博客-CSDN博客_upper_bound

#include<bits/stdc++.h>
using namespace std;
int main(){
    long long int n,q,k,x,a[100005],b[100005],i,z,y;
    cin>>n>>q;
    for(i=0;i<n;i++)cin>>a[i];
    sort(a,a+n);
    b[0]=0;
    for(i=0;i<n;i++)b[i+1]=b[i]+a[i];
    while(q--){
        cin>>k>>x;
        z=0;
        y=upper_bound(a,a+n,x)-a;
         if(y<k)
             z=b[y];
        else z=b[y]-b[y-k];
        cout<<z<<endl;
    }
    return 0;
}

 

B-小沙の博弈

链接:登录—专业IT笔试面试备考平台_牛客网
来源:牛客网
 

小沙和小雅在玩"拿石子游戏",他们两个人都十分聪明,均会选择最优的方法使得自己获胜。桌子上有 nnn 个石子 ,他们两个人面前均有排成一行的若干个格子,每个格子都可以置放无限多个石子。

小沙和小雅两个人交替进行操作,小沙先行,每次操作可以从桌子上拿走任意正整数个石子,将其置放于自己面前第一个没有石子的格子里。

当桌上的石子数为 000 时游戏结束,按照两人格子中石子数目组成序列的字典序判断胜负,字典序小的人获胜。

字典序:你有两个序列 aaa 和 bbb ,两个序列从前往后第一个不相同的字符分别为 aia_iai​ , bib_ibi​ ,如果 ai<bia_i < b_iai​<bi​ ,那么我们称序列 a<ba < ba<b 。如果两个序列完全相同,那么他们的字典序相等。

输入描述:

第一行输入一个整数 nnn ,1≤n≤1051 \leq n \leq 10^51≤n≤105。

输出描述:

输出一行字符串。

当小沙获胜时输出字符串"Sajin-win!"(不含引号)。

当小雅获胜时输出字符串"Yaya-win!"(不含引号)。

如果两个都没有获胜,那么输出字符串"win-win!"(不含引号)。

示例1

输入

复制2

2

输出

复制win-win!

win-win!

说明

 

小沙先手拿一个,小雅在拿一个,石子被用完了,他们的序列分别为

1

1

字典序相同,所以平局。

示例2

输入

复制3

3

输出

复制Yaya-win!

Yaya-win!

//如果n是偶数,那么结果一定是平局,题目已经说了他们两个人都十分聪明,均会选择最优的方法使得自己获胜,其次就是小雅获胜,因为奇数情况下,小沙一定会比小雅多取以此,而题目是小数获胜,可以自己尝试多举几个例子。

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin>>n;
    if(n%2==0)cout<<"win-win!";
    else cout<<"Yaya-win!";
    return 0;
}

 

H-小沙の店铺

//同样先给出错误代码,便于对比。首先来说,根据输入描述,那么y=1,k=2,但又与样例说明不符,所以应该是y=2,k=1,广播也说了,对此题样例说明做了更正,不过我始终没理解样例说明的最后一条,为什么最后只涨价了一元。

#include<bits/stdc++.h>
using namespace std;
int main(){
    long long x,y,k,n,t,s=0,a=0,b=0;
    cin>>x>>k>>y>>n>>t;
    for(int i=n;i>=1;i--){
        s+=i*x;b++;
        if(s>=t){a=1;break;}
        if(i>k)x+=y;
    }
    if(a)cout<<b;
    else cout<<"-1";
    return 0;
}

//后面发现,从根本上就理解错了题目,注意是每卖出k件就上涨y元,我们解释样例,n=5,最开始x=10,第一个顾客买了5,此时收益b=50元,然后每卖出2件涨价1元,现在卖出5件,所以涨价2元,并且遗留一件;到第二个顾客时,他买了4件,每件x=12,所以又收益48,加上之前剩的一件,现在卖出去5件,同样涨价2元;第三个顾客,买了3件,每件x=14,又收益42,加上前面剩的一件,现在卖出去四件,同样涨价2元;第四个顾客,买了2件,每件x=16,又收益32,此时收益已经等于t了,我们不妨继续解释,此时卖出去2件,所以只涨价1元,所以x=17.

b是统计当前总收益,d统计顾客数,a用来标记,z=当前顾客购买量,加上上一个顾客剩余量除以k,可以把z理解为涨价的倍率,c是每次剩余数。

#include<bits/stdc++.h>
using namespace std;
int main(){
    long long x,y,k,n,t,a=0,b=0,i,z=0,c=0,d=0;
    cin>>x>>y>>k>>n>>t;
    for(i=n;i>=1;i--){
        b+=i*x;d++;
        if(b>=t){a=1;break;}
        z=(i+c)/k;
        c=i+c-z*k;
        x+=z*y;
    }
    if(a)
    cout<<d;
    else cout<<"-1";
    return 0;
}

K-小沙の抱团 easy

// 要使最后的人数最少,这个数其实可以确定是2,那么每次淘汰人数就应该较一半多一点。

我的代码错在了两个点,第一,n=1和n=2的情况之间输出0,虽然最开始我是这样写的,但在后面我改成了1,这点是源于越找越错,就是我感觉其他部分代码没问题的情况下产生了这部分代码的质疑;第二,输出应该在else内,如果这点对了,估计前面第一点错误也不会继续了,如果这点不对,则只会通过百分之98的样例,因为1和2已经输出0,再输出0就无法通过,通过代码部分可以进行优化。

//优化代码

//错误代码 

#include<bits/stdc++.h>
using namespace std;
int main(){
    long long n,x,y=0;
    cin>>n;
    x=n;
    if(n==2||n==1)cout<<"1";
    else {
        while(n!=2){
            if(n%2==0)x=(x+2)/2;
            else x=(x+1)/2;
            n=x;
            y++;
        }
    }cout<<y;
    return 0;
}

//正确代码 

#include<bits/stdc++.h>
using namespace std;
int main(){
    long long n,x,y=0;
    cin>>n;
    x=n;
    if(n==2||n==1)cout<<"0";
    else {
        while(n!=2){
            if(n%2==0)x=(x+2)/2;
            else x=(x+1)/2;
            n=x;
            y++;
        }
        cout<<y;
    } 
    return 0;
}

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

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

相关文章

Mac电脑运行速度又卡又慢如何解决?CleanMyMacX2023最新版

CleanMyMac X为您喜爱的东西腾出空间。体验一系列巧妙的新功能&#xff0c;CleanMyMac可让您安全智能地扫描和清理整个系统&#xff0c;删除大量未使用的文件&#xff0c;缩小iPhoto图库的大小&#xff0c;卸载不需要的应用程序或修复不正常工作的应用程序&#xff0c;管理所有…

ARM异常处理

1.ARM异常源1.1 异常模式2.ARM异常响应CPSR内存储的是当前模式。2.1 异常向量表每个异常源只有四个字节的存储空间&#xff0c;所以不在向量表中写异常处理程序&#xff0c;而是写跳转指令。2.2 IRQ异常举例

产业互联网曾被认为是一个生搬硬凑出来的概念

有关产业互联网的质疑&#xff0c;依然还在耳畔会响。但&#xff0c;我们却无可避免地进入到了产业互联网的周期里。这听上去有些耸人听闻&#xff0c;却在真实地发生着。曾经&#xff0c;产业互联网被认为是一个生搬硬凑出来的概念&#xff0c;甚至还有人认为&#xff0c;它仅…

垃圾渗滤液膜后稳定出水水质稳定工艺

垃圾渗滤液的来源及水质特点 垃圾渗滤液是垃圾在堆放和填埋过程中由于发酵和雨水的淋洗、冲刷以及地表地下水的浸泡出来的污水。 当垃圾堆体的湿度超过其持水能力后&#xff0c;垃圾堆体内悬浮的或溶解的有机污染物和重金属等无机污染物将会随之一块溶出&#xff0c;便会产生渗…

大学生需要配备什么电子产品、上大学必备电子产品推荐清单

又是一年开学季&#xff0c;最近我们这里的中小学已经陆陆续续通知开学了。大学生正式开学还需要一段时间&#xff0c;作为大学生在入学之前&#xff0c;一定要准备好各种学习和生活物资。对于大学生而言&#xff0c;有大把的时间可以用来快活&#xff0c;而现在数码产品又成为…

中国电子学会2022年06月份青少年软件编程Scratch图形化等级考试试卷四级真题(含答案)

2022-06 Scratch四级真题 分数&#xff1a;100 题数&#xff1a;29 测试时长&#xff1a;100min 一、单选题(共15题&#xff0c;共30分) 1.执行下列程序&#xff0c;说的内容是&#xff1f;&#xff08;D&#xff09;(2分) A.使 B.命 C.初 D.心 答案解析&#xff1a;注…

Golang微服务基础技术

单体式和微服务 单体式架构服务 ------过往大家熟悉的服务器 特性&#xff1a; 1.复杂性随着开发越来越高&#xff0c;遇到问题解决困难。 2. 技术债务逐渐上升 3. 耦合度高&#xff0c;维护成本大 出现bug&#xff0c;不容易排查 解决旧bug&#xff0c;会出新bug 4. 持续交付…

“深度学习”学习日记。卷积神经网络--整体结构

2023.2.1 一、全连接层神经网络&#xff1a; 之前学习的神经网络称为 全连接神经网络 &#xff08; Fully-Connected&#xff09;&#xff0c;它的特点就是相邻层所有的神经元都有联接&#xff0c;通过Affine层实现全连接层。 在全连接层神经网络中&#xff0c;Affine层后面…

【ROS-Navigation】—— DWA路径规划算法解析

文章目录前言1. 涉及的核心配置文件与启动文件1.1 demo01_gazebo.launch1.2 nav06_path.launch1.3 nav04_amcl.launch1.4 nav05_path.launch1.5 move_base_params.yaml1.6 dwa_local_planner_params.yaml2. 调参时的一些经验与心得2.1 DWA算法流程2.2 对costmap的参数进行调整2…

1. Mybatis基础

文章目录1. Mybatis 简介2. Mybatis 快速入门3. 使用 idea 写 SQL4. Mapper 代理开发5. MyBatis 核心配置文件1. Mybatis 简介 MyBatis 是一款优秀的持久层框架&#xff0c;用于简化 JDBC 开发。 官方文档&#xff1a;https://mybatis.org/mybatis-3/zh/index.html 持久层&am…

GoogLeNet——网络实战

文章目录摘要&#x1f407;1 项目结构&#x1f407;2 划分训练集和测试集&#x1f407;3 计算mean和Standard&#x1f407;3.1 标准化的作用&#x1f407;3.2 归一化的作用&#x1f407;4 训练&#x1f407;4.1 导入项目使用的库&#x1f407;4.2 设置随机因子&#x1f407;4.3…

Java单例模式演示与理解

目录单例模式1、饿汉式2、懒汉式3、DSL懒汉式&#xff08;双重锁懒汉模式&#xff09;静态内部类懒汉式单例模式的如何破坏4、使用枚举类单例模式 为什么使用单例模式&#xff1f; 单例模式确保一个类在内存中只会有同一个实例对象存在。不管声明获取实例对象多少次都是内存中…

2023年网络安全八大预测!

随着创新技术的不断兴起&#xff0c;以及网络犯罪的日益专业化&#xff0c;网络安全攻击风险仍在持续增长。可以预见&#xff0c;2023年的网络安全形势依然严峻&#xff0c;需要国家不断完善网络安全政策和法规&#xff0c;网络安全企业积极创新网络安全防护技术。瑞数信息作为…

Allegro如何导出和导入器件模型Signal_Model操作指导

Allegro如何导出和导入器件模型Signal_Model操作指导 在用Allegro做PCB设计的时候,通常需要给器件加上Signal_Model,在做等长的时候用到的非常频繁。 Allegro除了可以给器件添加模型,还支持从一块加好模型的BRD导入到另外一块BRD中, 如下图,需要把R7002的Signal_Model导入…

剪报浏览器:可以自己设计网页的浏览器

总的功能就是一句话“不同网站的精华内容裁剪下来&#xff0c;合并到一处浏览”把自己关注的网页版块从不同网站上裁剪下来放在一个页面里&#xff0c;一次刷新就可以看到不同网站的最新内容&#xff0c;而不用逐个打开网站去看&#xff0c;提高了上网的效率。关键特征汇聚浏览…

排序算法(带动图)

0、算法概述0.1 算法分类十种常见排序算法可以分为两大类&#xff1a;比较类排序&#xff1a;通过比较来决定元素间的相对次序&#xff0c;由于其时间复杂度不能突破O(nlogn)&#xff0c;因此也称为非线性时间比较类排序。非比较类排序&#xff1a;不通过比较来决定元素间的相对…

【数据结构初阶】第七篇——二叉树的顺序结构及实现(堆的向下,向上调整算法)

二叉树的顺序结构 堆的概念及结构 堆的向下调整算法 堆的向上调整算法 堆的实现 初始化堆 销毁堆 打印堆 堆的插入 堆的删除 获取堆顶的数据 获取堆的数据个数 堆的判空 建堆的时间复杂度 二叉树的顺序结构 普通二叉树是不适合用数组来存储的,因为可能会导致大量…

为nginx配置好看的错误提示页面

前言 nginx默认错误页面确实有些丑哈&#xff0c;leeader让我换一个样式 &#xff0c;我就来喽&#xff01; 为nginx配置好看的错误提示页面前言1 找异常页原始页2 win上替换3 再linux服务器上替换4 不生效解决办法样式显示不正确6 错误页源码1 找异常页 原始页 nginx默认错误…

2个月快速通过PMP证书的经验

01 PMP证书是什么&#xff1f; 指的是项目管理专业人士资格认证。它是由美国项目管理协会&#xff08;Project Management Institute(简称PMI)&#xff09;发起的&#xff0c;严格评估项目管理人员知识技能是否具有高品质的资格认证考试。其目的是为了给项目管理人员提供统一的…

初学者的Metasploit教程 - 从基础到高级

Metasploit是使用最广泛的渗透测试工具之一&#xff0c;是一个非常强大的多合一工具&#xff0c;用于执行渗透测试的不同步骤。 文章目录前言安装Metasploit在 Linux 上安装 Metasploit了解 Metasploit 的版本并更新渗透测试的基础知识1. 信息收集/侦察2. 漏洞分析3.渗透4. 渗透…