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

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

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

    首先,你仔细读题了吗 请仔细读题。 题目要求是可以出现2 * 3 = 6 的情况的,这是个小坑 起码我被坑到了 这就迫使我们不能使用两个数组分别存2的i次方和3的j次方 错误写法: 正确的思路是这样的: 定义一个find函数(简称fd): fd函数用于找出所有从1到n的AC数,并返回一个包含这些数的vector。 在循环中,对每个数 i 进行检查: 通过while循环去除 i 中所有的2和3。如果剩下的数为1,则 i 是AC数。 将AC数添加到 numbers向量中。 接着来看主函数: 在 main 函数中,首先读取输入的整数n。 调用 findACNumbers 函数来获取所有的AC数。 输出所有的AC数,用空格隔开。 最后,结合起来,加上头文件:

    userId_undefined

    吴泽均

    秩序白银
    36阅读
    0回复
    1点赞
  • 我们大题小做,简单一点(题解)

    #include<iostream> using namespace std; int main(){ int a,n,c; cin>>a; for(int i=2;i<=a;i++){ n=0; c=i; if(c2||c3){ cout<<i<<" "; } else{ while(n0){ if(c1){ cout<<i<<" "; break; } if(c%20){ c=c/2; } else if(c%30){ c=c/3; } else{ n++; } } } } return 0; }

    userId_undefined

    LS_YZY

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