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

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

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

    解: 一定要开心

    userId_undefined

    孤笑客'◡'

    出道萌新空间掌握者
    17阅读
    0回复
    1点赞
  • 第二个题解

    #include <bits/stdc++.h> #define int long long using namespace std; int head[5005],sum[5005],nxt[5005],to[5005],n; bool vis[5005]; int idx,ans; inline void addedge(int a,int b) { to[idx]=b; nxt[idx]=head[a]; head[a]=idx++; } inline void init() { for(int i=1;i<=n;i++) { for(int j=2;j<=n/i;j++) { sum[i*j]+=i; } } } inline int dfs(int id) { int d1=0,d2=0; for(int i=head[id];i!=-1;i=nxt[i]) { int d=dfs(to[i])+1; if(d>=d1)d2=d1,d1=d; else if(d>d2)d2=d; } ans=max(ans,d1+d2); return d1; } signed main() { cin>>n; init(); memset(head,-1,sizeof head); for(int i=2;i<=n;i++) { if(sum[i]<i) { addedge(sum[i],i); vis[i]=true; } } for(int i=1;i<=n;i++) { if(!vis[i])dfs(i); } cout<<ans<<endl; return 0; }

    userId_undefined

    还没想好

    时间刺客模拟·模拟练习生贪心·贪心尝试者分治·分治练习生递归·套娃学徒格式·格式排版员
    0阅读
    0回复
    0点赞
暂无数据

提交答案之后,这里将显示提交结果~

首页