wenbao与数论(大白书)
最大公约数之和
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&category=26&problem=2421&mosmsg=Submission+received+with+ID+18788108
输入n 输出gcd(i,j) 1<=i<j<=n总和
1 #include <iostream> 2 using namespace std; 3 #define REP(i, x, n) for(int i = x; i < n; i++) 4 #define ll long long 5 const int maxn = 4000005; 6 int phi[maxn], p[maxn]; 7 ll f[maxn], s[maxn]; 8 bool vis[maxn]; 9 void Euler(int n){ 10 int i, j, k, cnt = 0; 11 phi[1] = 1; 12 for (i = 2; i < n; ++i){ 13 if (!vis[i]){ 14 p[cnt++] = i; 15 phi[i] = i - 1; 16 } 17 for (j = 0; j < cnt && i * p[j] < n; ++j){ 18 vis[i * p[j]] = true; 19 if (i % p[j]) phi[i * p[j]] = phi[i] * phi[p[j]]; 20 else { 21 phi[i * p[j]] = phi[i] * p[j]; 22 break; 23 } 24 } 25 } 26 } 27 int main(){ 28 Euler(maxn); 29 REP(i, 1, maxn){ 30 for(int j = i*2; j < maxn; j += i){ 31 f[j] += i * phi[j/i]; 32 } 33 } 34 s[2] = f[2]; 35 REP(i, 3, maxn) s[i] = s[i-1] + f[i]; 36 int n; 37 while(scanf("%d", &n) && n){ 38 printf("%lld\n", s[n]); 39 } 40 return 0; 41 }
只有不断学习才能进步!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用