码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Codeforces Round #822 (Div. 2) C. Removing Smallest Multiples


     iniput:

    1. 6
    2. 6
    3. 111111
    4. 7
    5. 1101001
    6. 4
    7. 0000
    8. 4
    9. 0010
    10. 8
    11. 10010101
    12. 15
    13. 110011100101100

    output:

    1. 0
    2. 11
    3. 4
    4. 4
    5. 17
    6. 60

    题目大意:给我么一个集合s,s中包含1~n所有数字,现在我们要进行一种操作,操作如下:首先选定一个数字k,在集合中存在k的倍数,然后我们可以删除k的最小的倍数,注意k也是自己的倍数,代价为k,现在给我们一个长度为n的01序列,第i个字符为1表示在进行所有操作之后数字i没有被删除,否则为0就是被删除了,问我们将原来的集合变成现在集合所需要的最小花费是多少?

    解题思路:贪心地从小到大枚举每一个数字,对于每一个数字从小到大枚举它的所有倍数,如果一旦发现当前枚举的倍数在最终的集合中没有被删除,那么立即退出,在枚举的时候要一边计算最终的代价和,注意一个数字只能被一个对应的k给删除,我们要避免一个数被多个数字删除的情况,所以对需要删除的数字我们也要记录一下该数字是否在之前已经被删除。

    总复杂度NlogN

    上代码:

    1. #include <iostream>
    2. #include <cstring>
    3. #include <cstdio>
    4. #include <algorithm>
    5. using namespace std;
    6. const int N=1e6+10;
    7. int t,n,a[N],b[N];
    8. int main() {
    9. cin>>t;
    10. while(t--) {
    11. scanf("%d",&n);
    12. for(int i=1; i<=n; i++) {
    13. scanf("%1d",&a[i]);
    14. b[i]=a[i];//b数组记录数字是否在之前就已经被删除
    15. }
    16. long long ans=0;
    17. for(int i=1; i<=n; i++) {
    18. for(int j=1; i*j<=n; j++)
    19. if(a[i*j]==0) {
    20. if(b[i*j]==0) {
    21. ans+=i;
    22. b[i*j]=1;
    23. }
    24. } else
    25. break;
    26. }
    27. cout<<ans<<endl;
    28. }
    29. return 0;
    30. }

  • 相关阅读:
    express学习33-多人管理25node.js—安装bcrypt出现错误的解决办法
    Typescrip编译选项
    【MATLAB】(高数)
    数据仓库数据集成开源工具
    如何让自己的精力集中 Maven自学笔记 马云演讲观看
    外汇天眼:交易的本质就是要解决这两个问题!
    五、鼎捷T100生产管理之报工
    精准突击!Mysql亿级数据开发手册,GitHub 132k starts | 实战解析。
    ruoyi-cloud-plus添加一个不要认证的公开新页面
    基础架构之Mongo
  • 原文地址:https://blog.csdn.net/weixin_54562114/article/details/127096874
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号