码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 1626C - Monsters And Spells ,D - Carry Bit 组合数学


    1626C - Monsters And Spells 

    一开始想的是倒着去遍历,如果h[i]<=k[i]-k[i-1]就说明可以从1开始加,否则就不能断开,但是这样忽略了下面的情况,即h[i-1]也不是最大值,需要从k[i-2]的地方连续加,所以就蔫了

    3
    1 2 3
    1 1 3

    看题解发现雀氏是要从后面开始看的,并且后面的大小是可以决定前面的数的,设一个f数组表示第i位需要多大才可以满足条件,即f[i]=max(h[i],f[i]-(k[i]-k[i-1]);

    然后接着分析就可以了,还是一样,如果f[i]<=k[i]-k[i-1]就可以从1开始加,否则就不能重新开始,这两种情况对应着两种等差数列求和,分别做一下就可以

    CF1626C Solution - Alejandro 的小屋 - 洛谷博客

    1. #include
    2. //#pragma-GCC-optimize("-Ofast");
    3. #define int long long
    4. #define ll __int128
    5. #define lowbit(x) ((x)&(-x))
    6. #define endl '\n'
    7. #define pause system("pause")
    8. using namespace std;
    9. const int N=1e6+5;
    10. const int mod=1e9+7;
    11. const int inf=1e18;
    12. int qpow(int a,int b)
    13. {
    14. int res=1;
    15. while(b)
    16. {
    17. if(b&1) res=res*a%mod;
    18. a=a*a%mod;
    19. b>>=1;
    20. }
    21. return res;
    22. }
    23. int getinv(int a){return qpow(a,mod-2);}
    24. int t,n,k[N],h[N],f[N];
    25. signed main()
    26. {
    27. //ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    28. cin>>t;
    29. while(t--)
    30. {
    31. cin>>n;k[n+1]=f[n+1]=0;
    32. for(int i=1;i<=n;i++) cin>>k[i];
    33. for(int i=1;i<=n;i++) cin>>h[i];
    34. f[n]=h[n];
    35. for(int i=n-1;i>=1;i--)
    36. {
    37. f[i]=max(h[i],f[i+1]-(k[i+1]-k[i]));
    38. // cout<
      }
    39. int ans=(1+f[1])*f[1]/2,las=f[1];
    40. for(int i=2;i<=n;i++)
    41. {
    42. if(f[i]<=k[i]-k[i-1]) ans+=(1+f[i])*f[i]/2,las=f[i];
    43. else
    44. {
    45. ans+=(las+1+las+k[i]-k[i-1])*(k[i]-k[i-1])/2;las=las+k[i]-k[i-1];
    46. }
    47. }
    48. cout<
    49. }
    50. return 0;
    51. }

  • 相关阅读:
    【Linux】之Jumpserver堡垒机的部署/搭建
    天翎知识文档系统+群晖NAS,助力企业实现移动化学习
    常用的画流程图工具和脑图工具
    2022年大一网页期末作业(纯html+css实现)
    云原生数字化转型与金融信创建设,鱼和熊掌可兼得
    SpringBoot实现自定义environment中的value加密
    git |常用命令
    使用Speech to Text API进行语音到文本转换
    APISpace 汉语拆字API
    Typescript本地浏览器调试
  • 原文地址:https://blog.csdn.net/weixin_52621204/article/details/128001946
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号