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

【蓝桥杯每日一题】砍竹子

砍竹子

2024-12-7 蓝桥杯每日一题 砍竹子 STL 贪心

题目大意

这天, 小明在砍竹子, 他面前有 nn 棵竹子排成一排, 一开始第 ii 棵竹子的 高度为 h i h_i hi. 他觉得一棵一棵砍太慢了, 决定使用魔法来砍竹子。魔法可以对连续的一 段相同高度的竹子使用, 假设这一段竹子的高度为 HH, 那么用一次魔法可以 把这一段竹子的高度都变为 [ ⌊ H 2 ⌋ + 1 ] \begin{bmatrix}\sqrt{\lfloor\frac{H}{2}\rfloor+1}\end{bmatrix} [2H+1 ], 其中 [ x ] \begin{bmatrix}x\end{bmatrix} [x] 表示对 x 向下取整。小明想 知道他最少使用多少次魔法可让所有的竹子的高度都变为 1 。

解题思路

这个题使用到了 STL 的技巧,有些不好想,咱们一步一步分析。

  1. 当前值改变的次数是否要加,取决于与它相邻的元素是否相等,这时候我们只看前面相邻的元素。。

  2. 当相邻元素减小到同一个值的时候,只需要计算一次即可,这一次怎么算,就是这些相邻相同的所有元素的对头那个来算,其他的都不算。

  3. 可以通过模拟每一个数的一个变化历程,然后对比前后的数据变化发现那些数是可以变化的。

  4. 举例:

    7 6 2 4 1 2
    7 2 1     2
    6 2 1     12 1     0
    4   1     11     02 1     1
    
  5. 根据例子可以观察到每一个数的更新它所贡献的值只有与前一个数的变化历程不同的数的数量,那么就可以通过两个set集合来进行比较。

Accepted
#include <bits/stdc++.h>using namespace std;
typedef long long ll;int main()
{int n;cin>>n;ll res = 0;set<ll> pri;for(int i = 1;i <= n;i++) {ll t;cin>>t;set<ll> pre;while(t > 1) {pre.insert(t);if(!pri.count(t)) {res++;}t = sqrtl(t/2+1);}pri = pre;}cout<<res<<endl;return 0;
}
思考

这道题还是很难想出来的,必须通过模拟来观察规律求解!!!

备注

想要一起备赛的小伙伴可以看评论区添加讨论群!


http://www.mrgr.cn/news/79906.html

相关文章:

  • 黑马商城微服务复习(6)
  • MVC配置文件及位置
  • 【C语言】浮点数的原理、整型如何转换成浮点数
  • 计算机组成原理复习
  • 【漏洞复现】CVE-2022-26619 CVE-2022-32994 Arbitrary File Upload
  • 多发电站实现光伏发电预测的统一管理模式
  • CSDN原力值说明
  • mac 安装CosyVoice (cpu版本)
  • 通用定时器之输出比较的功能
  • 0001.简易酒店管理系统后台
  • MOTR: End-to-End Multiple-Object Tracking with Transformer
  • PyQt5入门(四)--------下拉选择框控件(comboBox)
  • 【Neo4J】neo4j docker容器下的备份与恢复
  • 微信小程序web-view 嵌套h5界面 实现文件预览效果
  • 餐饮平台数仓建模案例
  • Spann3R:基于DUSt3R的密集捕获数据增量式重建方法
  • day11 性能测试(4)——Jmeter使用(黑马的完结,课程不全)直连数据库+逻辑控制器+定时器
  • 分布式事物XA、BASE、TCC、SAGA、AT
  • 解决 MyBatis 中空字符串与数字比较引发的条件判断错误
  • ubuntu 安装 docker详细教程