acgo题库
  • 首页
  • 题库
  • 题单
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情题解(0)讨论(0)提交记录(0)
  • 题解

    #include <bits/stdc++.h> using namespace std; int a[1000005]; int main(){ int n,k,ans=0; cin>>n>>k; for (int i=1;i<=n;i++) { cin>>a[i]; } for(int i=1;i<=n;i++) { if(a[i]==1) { for(int j=i;j<=i+k-1;j++) { a[j]=0; } ans++; } } cout<<ans; return 0; }

    userId_undefined

    扬帆科技(GYF)

    倔强青铜
    53阅读
    0回复
    2点赞
  • O(n)的题解

    看了一下,目前题解都是 O(nk)O(nk)O(nk) 的,我也不知道为什么能过。 由于题目并没有说要输出数组,那么不妨考虑一种思路: O(n)O(n)O(n) 遍历数组,如果遍历到 aia_iai 是 111,就让 iii 往前跳 kkk 个位置。 最坏时间复杂度:O(n)O(n)O(n) 代码实现起来就简单了 100pts100pts100pts

    userId_undefined

    复仇者_澜

    秩序白银
    49阅读
    2回复
    1点赞
  • 答案

    #include <bits/stdc++.h> using namespace std; int a[1000005]; int main(){ int n,k,ans=0; cin>>n>>k; for (int i=1;i<=n;i++) { cin>>a[i]; } for(int i=1;i<=n;i++) { if(a[i]==1) { for(int j=i;j<=i+k-1;j++) { a[j]=0; } ans++; } } cout<<ans; return 0; }

    userId_undefined

    鲁玮博

    倔强青铜
    24阅读
    0回复
    0点赞
  • O(n)的题解

    userId_undefined

    复仇者_烟云

    倔强青铜
    6阅读
    0回复
    0点赞
首页