Description

作为体育委员,C君负责这次运动会仪仗队的训练。仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图)。

现在,C君希望你告诉他队伍整齐时能看到的学生人数。

Input

共一个数N。

Output

共一个数,即C君应看到的学生人数。

Sample Input

4

Sample Output

9

HINT

【数据规模和约定】   对于 100% 的数据,1 ≤ N ≤ 40000

Solution

以前看这题,无从下手

现在看这题,毫无意义

由于这个什么人在队列的左下角,所以我们先把第一列和最后一行去掉,剩下的变成一个矩阵

然后对于这个矩阵

\(ans'=\sum_{i=1}^n\sum_{j=1}^n[gcd(i,j)=1]\)

\(\ \ \ \ \ \ \ \ =\sum_{i=1}^n\mu(i)(\lfloor \frac{n}{i}\rfloor )^2\)

然后加上原来的最后一行和第一列的贡献,就是加2

答案就是\(ans=ans'+2\)

当然,这种做法要特判一下,因为我们剔掉了一行一列,那么当 \(n=1\) 的时候,答案特判,为0

  1. #include<bits/stdc++.h>
  2. #define ll long long
  3. #define db double
  4. #define ld long double
  5. const int MAXN=40000+10;
  6. int n,vis[MAXN],prime[MAXN],cnt,s[MAXN],mu[MAXN];
  7. ll res=0;
  8. template<typename T> inline void read(T &x)
  9. {
  10. T data=0,w=1;
  11. char ch=0;
  12. while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
  13. if(ch=='-')w=-1,ch=getchar();
  14. while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
  15. x=data*w;
  16. }
  17. template<typename T> inline void write(T x,char c='\0')
  18. {
  19. if(x<0)putchar('-'),x=-x;
  20. if(x>9)write(x/10);
  21. putchar(x%10+'0');
  22. if(c!='\0')putchar(c);
  23. }
  24. template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
  25. template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
  26. template<typename T> inline T min(T x,T y){return x<y?x:y;}
  27. template<typename T> inline T max(T x,T y){return x>y?x:y;}
  28. inline void init()
  29. {
  30. memset(vis,1,sizeof(vis));
  31. vis[0]=vis[1]=1;
  32. mu[1]=1;
  33. for(register int i=2;i<MAXN;++i)
  34. {
  35. if(vis[i])
  36. {
  37. prime[++cnt]=i;
  38. mu[i]=-1;
  39. }
  40. for(register int j=1;j<=cnt&&i*prime[j]<MAXN;++j)
  41. {
  42. vis[i*prime[j]]=0;
  43. if(i%prime[j])mu[i*prime[j]]=-mu[i];
  44. else break;
  45. }
  46. }
  47. for(register int i=1;i<MAXN;++i)s[i]=s[i-1]+mu[i];
  48. }
  49. int main()
  50. {
  51. init();
  52. read(n);
  53. if(n<=1)
  54. {
  55. puts("0");
  56. return 0;
  57. }
  58. n--;
  59. for(register int i=1;;)
  60. {
  61. if(i>n)break;
  62. int j=n/(n/i);
  63. res+=1ll*(n/i)*(n/i)*(s[j]-s[i-1]);
  64. i=j+1;
  65. }
  66. write(res+2,'\n');
  67. return 0;
  68. }

【刷题】BZOJ 2190 [SDOI2008]仪仗队的更多相关文章

  1. BZOJ 2190: [SDOI2008]仪仗队

    2190: [SDOI2008]仪仗队 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 2689  Solved: 1713[Submit][Statu ...

  2. BZOJ 2190: [SDOI2008]仪仗队( 欧拉函数 )

    假设C君为(0, 0), 则右上方为(n - 1, n - 1). 一个点(x, y) 能被看到的前提是gcd(x, y) = 1, 所以 answer = ∑ phi(i) * 2 + 2 - 1 ...

  3. bzoj 2190: [SDOI2008]仪仗队 线性欧拉函数

    2190: [SDOI2008]仪仗队 Time Limit: 10 Sec  Memory Limit: 259 MB[Submit][Status][Discuss] Description 作为 ...

  4. bzoj 2190 [SDOI2008]仪仗队(欧拉函数)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2190 [题意] n*n的正方形,在(0,0)格点可以看到的格子数目. [思路] 预处理 ...

  5. BZOJ——2190: [SDOI2008]仪仗队

    思路: 我们将其所在的位置设为(0,0),那么如果存在一个点(x,y),且有gcd(x,y)=k(k!=1),那么点(x/k,y/k)一定会将(x,y)挡住.而如果k=1,那么点(x,y)就一定会被看 ...

  6. [bzoj 2190][SDOI2008]仪仗队(线性筛欧拉函数)

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2190 分析:就是要线性筛出欧拉函数... 直接贴代码了: memset(ans,,sizeof ...

  7. BZOJ 2190 [SDOI2008]仪仗队 ——Dirichlet积

    [题目分析] 考虑斜率为0和斜率不存在的两条线上只能看到3人. 其余的人能被看见,当且仅当gcd(x,y)=1 ,然后拿卷积算一算 发现就是欧拉函数的前缀和的二倍. 注意2的情况要特判. [代码] # ...

  8. 2190: [SDOI2008]仪仗队(欧拉函数)

    2190: [SDOI2008]仪仗队 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 3235  Solved: 2089 Description 作 ...

  9. 【BZOJ】2190 [SDOI2008]仪仗队(欧拉函数)

    Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是 ...

随机推荐

  1. 使用Amplify Shader Editor优化特效Shader

    ASE相对于Shader Forge生成的代码更加干净, 用于制作特效的再合适不过,以下是使用ASE优化一个SF制作特效的经过: ## 分析美术用SF制作的Shader 懒得装SF, 直接分析代码可知 ...

  2. vue 使用ref获取DOM元素和组件引用

    在vue中可以通过ref获取dom元素,并操作它,还可以获取组件里面的数据和方法. HTML部分: <div id="app"> <input type=&quo ...

  3. 欧拉筛——$O(n)$复杂度的质数筛法

    欧拉筛法可以以\(O(n)\)的时间,空间复杂度求出\(1-n\)范围内的所有质数. 其核心思想是每个合数仅会被其最小的质因数筛去一次. See this website for more detai ...

  4. Centos7.2构建Python3.6开发环境

    1.安装python3.6 1.这里使用一台全新的腾讯云主机,首先获取linux系统版本信息. [root@VM_46_121_centos ~]# cat /etc/redhat-release C ...

  5. react-native 常规操作

    1.  关闭xcode打开模拟器的快捷键 , 等常规操作 https://www.jianshu.com/p/f6723f3406b7

  6. Teamproject Week7 --Scrum Meeting #1 2014.10.28

    这是团队的第一次会议,具体议题如下: 1)我们明确了团队成员的职责所需: PM职责:根据项目范围.质量.时间与成本的综合因素的考虑,进行项目的总体规划与阶段计划.  控制项目组各成员的工作进度,即时了 ...

  7. 学习Mybatis的两个必须的jar包分享

    百度云盘:http://pan.baidu.com/s/1nuNxRcd 提取码:t765(好像不需要提取码,不太会用云盘...) 自己学习mybatis的时候去找这两个jar包也是不容易,特别分享一 ...

  8. 渡过OO的死劫,了解规格的意义——OO第三次博客总结

    当熬过了一次次黑暗,迎接我们的却是被扣的惨不忍睹的JSF ┭┮﹏┭┮ 一.总结调研 规格的历史 传统科学的特点是发现世界,而软件的特点是构造世界.软件的最底层就是0,1,两个离散的值.程序设计语言的三 ...

  9. 20135234mqy-——信息安全系统设计基础第七周学习总结

    第六章 存储器层次结构 存储器系统是一个具有不同容量,成本和访问时间的存储设备的层次结构. CPU寄存器保存着最常用的数据. 靠近CPU的小的,快速的高速缓存存储器作为一部分存储在相对较慢的主存储器( ...

  10. OC中的私有方法

    1.不写在.h文件中 2.不写在.m文件中 一.私有方法: 没有在.h文件当中进行声明的方法在OC中都被称为私有方法 私有方法子类是无法继承到的