【牛客】几何糕手、国际裁判带师、数位dp?、灵异背包、矩阵快速幂签到、第一次放学

文章目录

  • 《几何糕手》
    • 题目描述
    • 思路
    • 代码
  • 《国际裁判带师》
    • 题目描述
    • 思路
    • 代码
  • 《数位dp?》
    • 题目描述
    • 思路
    • 代码
  • 《灵异背包》
    • 题目描述
    • 思路
    • 代码
  • 《矩阵快速幂签到》
    • 题目描述
    • 思路
    • 代码
  • 《第一次放学》
    • 题目描述
    • 思路
    • 代码

《几何糕手》

题目链接

题目描述

“芝士肾么?”

地上有一根木桩,在木桩上栓有一根长度为 a 的木绳,木绳的末端还栓有一根长度为 b 的木棍,现在小沙想要知道,木棍可能扫过的位置在地面上的投影面积有多大。

输入描述
第一行输入两个正整数 a,b,代表木绳以及木棍的长度。
保证有1≤a,b≤100。

输出描述
输出一个数字代表答案,答案保留10位小数。

示例1:
输入:

1 1

输出:

12.5663706144

思路

把木棍和绳子的长度加起来作为圆的半径,然后直接求圆的面积即可,这里想要使用圆周率Π的话可以使用acos(-1)来表示

代码

#include<bits/stdc++.h>
using namespace std;
 
int main()
{
    double a,b;
    cin>>a>>b;
    printf("%.10lf",acos(-1)*pow(a+b,2));
    return 0;
}

《国际裁判带师》

题目链接

题目描述

“蒸馍?你不福气?”

在很多比赛中,会有如下图所示的计分表,每次得分之后会翻动来表示得分。
在这里插入图片描述
先给定如上图所示记分表,并给定一个长度为n 的比赛获胜记录,小沙需要记录整场比赛中,每次计分表变化之后,数字 0 出现了多少次。
小沙:“ACMer,帮帮我”。

输出描述
链接:
第一行,输入一个长度不超过 n 的字符串,保证字符串中仅包含 ab
其中 a 代表红方获胜得一分,b 代表蓝方获胜得一分。
保证有1≤n≤99。

示例1:
输入:

aab

输出:

8

说明:

第一次红方得分,计分表变成 0001,出现了3 个 0。 第二次红方得分,计分表变成 0002,出现了3 个 0。
第一次蓝方得分,计分表变成 0102,出现了 2 个 0。 总计出现了 8 次数字 0。

思路

遍历题目给出的字符串,记录每一个环节a和b对应的分数然后对每一个和环节a和b的分数计算有多少个0。

代码

#include<bits/stdc++.h>
using namespace std;

int solve(int n)
{
    int ans=0;
    while(n>0)
    {
        if(n%10==0)ans++;
    }
    return ans;
}

int main()
{
    string s;
    cin>>s;
    int a=0,b=0;
    int ans=0;
    for(int i=0;i<s.size();++i)
    {
        if(s[i]=='a')a++;
        else b++;
        if(a/10==0)ans++;
        if(a%10==0)ans++;
        if(b/10==0)ans++;
        if(b%10==0)ans++;
    }
    cout<<ans;
    return 0;
}

《数位dp?》

[题目链接](https://ac.n
owcoder.com/acm/contest/66877/A)

题目描述

给定一个数字n,你可以对它进行接下来的操作——

  • 选择数字中任意一个数位删除

例如对1024选择操作百位,数字则变成了124;对1024选择操作千位,数字则变成了024

我们称一个数字是干净的,当且仅当数字满足以下任意一种情况:

  • 这个数字是偶数且不含前导零
  • 这个数字为空

请问最少需要进行多少次操作,使得数字n变成干净

输入描述
第一行包含一个整数 n (1≤n≤109),表示这个数字的大小
输入的数字保证不含前导零

输出描述
输出最少需要的操作次数。
注意,因为一定能使得数字删成空,所以当前数字一定能变成干净的

示例1:
输入:

1024

输出:

0

说明:

当前数字无需操作便满足条件

示例2:
输入:

3

输出:

1

说明:

最少只需要删除一次即可把数字删成空
‘3’⇒’’

示例3:
输入:

233

输出:

2

说明:

最少只需要删除两次即可把数字删成偶数
233⇒23⇒2

思路

简单模拟,把这个数从后面往前面一直删除一直到遇到偶数就停止

代码

#include<bits/stdc++.h>
using namespace std;

int main()
{
    int n;
    cin>>n;
    int ans=0;
    while(n)
    {
        if(n%2==0)break;
        n/=10;
        ans++;
    }
    cout<<ans;
    return 0;
}

《灵异背包》

题目链接

题目描述

有n个正整数,现在,你可以选择将其中一些数放进灵异背包中,使得背包里面所有数的总和为偶数且最大,求能得到的最大值是多少?

注意:如果你不将任何数放进灵异背包,此时背包总和为0

输出描述
第一行包含一个正整数n (1≤n≤105 ),表示数字的数量
接下来n行包含n个正整数 a1 ,a2…,an (1≤ai ≤2×104),表示数字的大小

示例1:
输入:

3
2
5
6

输出:

8

说明:
当灵异背包里面有(2,5,6),此时总和为2+5+6=13,为奇数,不满足条件
当灵异背包里面有(2,6),此时总和为2+6=8,为偶数,且为最大值

示例2:
输入:

1
3

输出:

0

说明:

选择的灵异背包为空,总和为0

思路

偶数全部都可以加进来,奇数需要分类讨论,如果奇数个数是偶数个也可以全部加入,如果是奇数个就去掉最小的奇数

代码

#include<bits/stdc++.h>
using namespace std;

int main()
{
    int n;
    bool pd=0;
    long long minzhi=INT_MAX;
    long long ans=0;
    cin>>n;
    long long input;
    while(n--)
    {
        cin>>input;
        ans+=input;
        if(input&1)
        {
            pd^=1;
            minzhi=min(minzhi,input);
        }
    }
    if(pd)ans-=minzhi;
    cout<<ans;
    return 0;
}

《矩阵快速幂签到》

题目链接

题目描述

在这里插入图片描述

输入描述
一个正整数 (1≤n≤998244351)

输出描述
一个整数,对应答案。

示例1:
输入:

1

输出:

2

示例2:
输入:

2

输出:

3

思路

这道题就是诈骗题,无脑输出一下最前面的那几项找找规律就会发现直接输出n+1就可以了

代码

#include<bits/stdc++.h>
using namespace std;

int main()
{
    int n;
    cin>>n;
    cout<<(n+1)%998244353;
    return 0;
}

《第一次放学》

题目链接

题目描述

在这里插入图片描述

输入描述
在这里插入图片描述
输出描述
一个整数,表示目前学校里最多有多少同学是属于同一个班级的。

示例1:
输入:

6 3 3
3 1 2 3 3 2

输出:

3

思路

题目询问最多多少个同学是同一个班级,那我们直接找最大的那个班级进行对比,如果那个班级的人数更多那么剩下的n-k个人都是这个班级的,否则就是这个班级的人加上其他的班级的人,此时输出人数最大的班级的人数

代码

#include<bits/stdc++.h>
using namespace std;

int main()
{
    int n,m,k;
    int a[(int)1e5+10];
    cin>>n>>m>>k;
    int input;
    int maxzhi=0;
    for(int i=0;i<n;++i)
    {
        cin>>input;
        a[--input]++;
        maxzhi=max(maxzhi,a[input]);
    }
    if(maxzhi>n-k)cout<<n-k;
    else cout<<maxzhi;
    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python学习03—Python语法元素分析

一、程序的格式框架 1.1 代码高亮 代码高亮是Python编程环境根据代码不同含义&#xff0c;给予不同色彩标注的一种色彩辅组体系。在不同的代码编程环境中&#xff0c;代码高亮的表现形式各有不同。 1.2 缩进 缩进是一行代码开始前的空白区域&#xff0c;它用来表达程序的格式…

php比较运算,强相等(===)弱相等(==)表

弱相等&#xff08;&#xff09; 符号为&#xff1a; 规则为&#xff1a;只比较值&#xff0c;不比较类型&#xff0c;只要值对就为true 样例&#xff1a;比较整型123和字符串"123"&#xff0c;运行结果给出了true 弱相等表&#xff1a;* 代表在 PHP 8.0.0 之前为…

使用trace工具分析Mysql如何选择索引

背景说明 工作中,可能会遇到执行一个SQL,明明有索引,但是采用explain分析后发现执行结果并未走索引。甚至还有部分SQL语句相同就只是查询条件不一样也会出现有的走索引,有的不走索引情况。比如: 我的示例环境有个employees表,并有个idx_name_age_position的联合索引…

Dirichlet Process 4

每一个样本都有自己对应的&#xff0c;有多少个样本就有多少个 如果有a个相等&#xff0c;那么我们能够相信这a个对应的样本x属于同一类的 要保证能够相等&#xff0c;所以要从一个离散的分布&#xff0c;即G中产生 所以有如下关系 图模型如下&#xff1a; &#xff0c;这里面…

顺序表和链表【数据结构】【基于C语言实现】【一站式速通】

线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使 用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串... 线性表和链表的物理结构&#xff1a; 线性表在逻辑上是线性结构&…

【数据结构】二叉树算法讲解(定义+算法原理+源码)

博主介绍&#xff1a;✌全网粉丝喜爱、前后端领域优质创作者、本质互联网精神、坚持优质作品共享、掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战✌有需要可以联系作者我哦&#xff01; &#x1f345;附上相关C语言版源码讲解&#x1f345; &#x1f44…

Lingo数学建模基础

1.基本运算符 1.1算数运算符 1.2逻辑运算 #not# 否定操作数的逻辑值&#xff0c;一元运算符 #eq# 若两运算数相等&#xff0c;则为true,否则为false #ne# 若两运算数不相等&#xff0c;则为true,否则为false #gt# 若左边运算数严格大于右边&#xff0c;则为true,否则为…

Nacos源码下载与运行

早先在linux环境下搭建过nacos环境 即Centos安装部署nacos实战&#xff0c;本次是从官网上下载源码&#xff0c;本地运行看看&#xff0c;记录过程&#xff0c;方便备查。 第一步、Nacos源码下载 推荐到nacos官网下载 Github地址&#xff0c;本次选择最新版&#xff0c;1.4.7…

x-cmd pkg | ascii-image-converter - 图像转 ASCII 艺术照工具

目录 简介首次用户功能特点竞品和相关作品进一步阅读 简介 ascii-image-converter 是图像转换工具&#xff0c;用于将图像转换为 ascii art 图片并在控制台上打印。 首次用户 使用 x env use ascii-image-converter 即可自动下载并使用 在终端运行 eval "$(curl https:/…

智能机器人与旋量代数(9)

Chapt 3. 螺旋运动与旋量代数 3.1 螺旋运动 螺旋运动是关于一条空间直线的一个旋转运动&#xff0c;并伴随沿此直线的一个平移。是一种刚体绕空间轴 s s s旋转 θ \theta θ角&#xff0c;再沿该轴平移距离 d d d的复合运动&#xff0c;类似螺母沿螺纹做进给运动的情形。 一…

NQA网络质量分析

概念 网络质量分析是设备上集成网络测试功能,不仅可以实现对网络运行情况的准确测试,还可以输出统计信息,有效的节约成本。 NQA可以检测网络上运行的各种协议的性能,使运营商能够实时采集到各种网络运行指标。 例如:HTTP的总时延、TCP连接时延、DNS解析时延、文件传输速…

【好用的AI工具Kimi Chat】帮助提高面试效率

一、背景 年前裁员潮&#xff0c;不少人离职找工作&#xff0c;以及年后金三银四&#xff0c;也是求职高峰期。如何更高效的复习技术知识&#xff0c;以及特别是横纵向比对有总结性的问题。本文以面试【测试开发】的岗位为例&#xff0c;对面试题进行拓展&#xff0c;让AI帮助…

MMagic调试(训练)dreambooth

时间&#xff1a;2024.1.23 1.dreambooth配置文件 dreambooth在mmagic中的路径&#xff1a; configs/dreambooth本文以dreambooth.py 为例 configs/dreambooth/dreambooth.py2.下载数据集 下载数据集并保存至data/dreambooth/&#xff0c;数据集&#xff1a; https://dri…

buffer pool和查询缓存的区别

在学习buffer pool的时候我产生了疑问&#xff0c;buffer pool和查询缓存是一个东西吗&#xff1f; 结论&#xff1a;不是一回事。 buffer pool buffer pool我之前介绍过&#xff0c;它的出现是为了提高查找效率&#xff0c;缓存磁盘上的数据页。 buffer pool虽说是内存中的一…

【GitHub项目推荐--不错的 C++开源项目】【转载】

01 C 那些事 这是一个适合初学者从入门到进阶的仓库&#xff0c;解决了面试者与学习者想要深入 C及如何入坑 C的问题。 除此之外&#xff0c;本仓库拓展了更加深入的源码分析&#xff0c;多线程并发等的知识&#xff0c;是一个比较全面的 C 学习从入门到进阶提升的仓库。…

Java面试题之基础篇

文章目录 一&#xff1a;谈谈你对面向对象的理解二&#xff1a;JDK、JRE、JVM三者区别和联系三&#xff1a;和equals比较四&#xff1a;hashCode与equals五&#xff1a;final六&#xff1a;String、StringBuffer、StringBuilder七&#xff1a;重载与重写的区别&#xff1f;八&a…

Leetcode27-判断一个数的数字技术是否等于数位的值(2283)

1、题目 给你一个下标从 0 开始长度为 n 的字符串 num &#xff0c;它只包含数字。 如果对于 每个 0 < i < n 的下标 i &#xff0c;都满足数位 i 在 num 中出现了 num[i]次&#xff0c;那么请你返回 true &#xff0c;否则返回 false 。 示例 1&#xff1a; 输入&am…

网络安全--防御保护02

第二天重要的一个点是区域这个概念 防火墙的主要职责在于控制和防护---安全策略---防火墙可以根据安全策略来抓取流量之后做出对应的动作 防火墙的分类&#xff1a; 单一主机防火墙&#xff1a;专门有设备作为防火墙 路由集成&#xff1a;核心设备&#xff0c;可流量转发 分…

Git学习笔记(第3章):Git常用命令

目录 3.1 设置用户签名 3.2 初始化本地库 3.3 查看本地库状态 3.4 添加暂存区 3.5 提交本地库 3.6 历史版本 3.7 修改文件 3.8 版本穿梭 小结 命令 作用 git config --global user.name 用户名 设置用户签名 git config --global user.email 邮箱 设置用户签名 …

Hikvision综合安防管理平台files;.css接口存在任意文件读取漏洞 附POC软件

免责声明&#xff1a;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该文章仅供学习用途使用。 1. Hikvisi…