经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C++ » 查看文章
cf1056B. Divide Candies(数论 剩余系)
来源:cnblogs  作者:自为风月马前卒  时间:2018/12/3 23:55:23  对本文有异议

题意

题目链接

求满足\(i^2 + j^2 \% M = 0\)的数对\((i, j)\)的个数,\(1 \leqslant i, j \leqslant 10^9, M \leqslant 1000\)

Sol

发这篇博客的目的就是为了证明一下我到底有多菜。

mdzz小学组水题我想了40min都没想出来。这要是出在NOIP 2019的话估计我又要做不出Day1T1了。。

\(i^2 + j^2 \% M = i \% M * i \% M + j \% M * j \% M\)

枚举剩余系即可

此题完结

  1. /*
  2. */
  3. #include<bits/stdc++.h>
  4. #define Pair pair<int, int>
  5. #define MP(x, y) make_pair(x, y)
  6. #define fi first
  7. #define se second
  8. #define int long long
  9. #define LL long long
  10. #define rg register
  11. #define pt(x) printf("%d ", x);
  12. #define Fin(x) {freopen(#x".in","r",stdin);}
  13. #define Fout(x) {freopen(#x".out","w",stdout);}
  14. using namespace std;
  15. const int MAXN = 1e6 + 10, INF = 1e9 + 10, mod = 1e9 + 7;
  16. const double eps = 1e-9;
  17. inline int read() {
  18. char c = getchar(); int x = 0, f = 1;
  19. while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
  20. while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
  21. return x * f;
  22. }
  23. int N, M, vis[3001][3001];
  24. int get(int l, int r) {
  25. return (r - l) / M + (l > 0);
  26. }
  27. main() {
  28. N = read(); M = read();
  29. int ans = 0;
  30. for(int i = 1; i <= M; i++) {
  31. for(int j = 1; j <= M; j++) {
  32. if((i * i + j * j) % M == 0) {
  33. vis[i % M][j % M] = 1;
  34. }
  35. }
  36. }
  37. for(int i = 0; i <= min(N, M); i++)
  38. for(int j = 0; j <= min(N, M); j++)
  39. if(vis[i][j] && ((i * i + j * j) % M == 0))
  40. (ans += get(i, N) * get(j, N));
  41. cout << ans;
  42. return 0;
  43. }
  44. /*
  45. */
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号