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

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

砍竹子

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     1
      2 1     0
    4   1     1
        1     0
      2 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.kler.cn/a/427524.html

相关文章:

  • python怎么打印心形
  • cmake: error while loading shared libraries: libssl.so.1.1
  • JVM 性能调优以实现高吞吐量和低延迟(内附相对较优调优参数)
  • Dashboard-Factory没图没真相的虚假BI
  • Elasticsearch Serverless 现已正式发布
  • macOS sequoia 15.1中应用程序“程序坞”没有权限打开
  • C++ String(字符串)和 float/double (浮点数)互转
  • Photohop关于数位板没有压力感,PS画笔的钢笔压力总是显示感叹号的问题解放方法
  • 嵌入式硬件设计 — 智能设备背后的隐形架构大师
  • redis实现基础分布式锁,自动续期,可重入分布式锁
  • 获取小数的整数和小数部分
  • 函数与模块
  • SQL高级应用——索引与视图
  • 【解决pycharm下site-packages文件标记为红色的问题】
  • 深度学习-54-AI应用实战之基于Yolo8的钢材表面缺陷检测
  • 1.mysql基础架构一条SQL查询语句是如何执行的?
  • 计算机网络原理之HTTP与HTTPS
  • 深入浅出 :理解 Go 的基本语法
  • 什么是 Gerotor 泵?他有什么特点?和齿轮有啥关系?
  • SPI驱动模型框架及spidev.c分析---学习记录