BZOJ 2190 仪仗队

       这道题的关键就是找到所有的点中,x与y互质的点,第一反应必定是暴搜,稍想一下可以从中分开求一半,但范围仍然限定了这条路行不通,仔细画了几张图后发现下图中从第三行起第k行可连fai k个,因此只需从fai3加到fai n即可。

程序如下:

#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <algorithm>
#include <cstring>

#define ll long long
#define ull unsigned long long

using namespace std;

bool f[40001];
ull p[40001];
ull ans[40001];

int main()
{
    int n,tot=0;
    cin >>n;
    if (n<=1)
    {
        cout <<0 <<endl;
        return 0;
    }

    memset(f,false,sizeof(f));
    f[1]=true;
    for (int i=2;i<=n;i++)
    {
        if (!f[i])
        {
            p[++tot]=i;
            ans[i]=i-1;
        }
        for (int j=1;(j<=tot)&&(i*p[j]<=n);j++)
        {
            f[i*p[j]]=true;
            if (i%p[j]==0)
            {
                    ans[i*p[j]]=ans[i]*p[j];
                    break;
            }
            else
            {
                ans[i*p[j]]=ans[i]*(p[j]-1);
            }
        }

    }

    long long pr=2;
    for (int i=2;i<=n-1;i++) pr+=ans[i];

    cout <<pr*2-1 <<endl;

    return 0;
 }

感谢各位观看我的博客,希望各位能有所收获。

时间: 2024-10-23 23:12:59

BZOJ 2190 仪仗队的相关文章

BZOJ 2190仪仗队【欧拉函数】

问题的唯一难点就是如何表示队长能看到的人数?如果建系,队长所在的点为(0,0)分析几组数据就一目了然了,如果队长能看到的点为(m,n),那么gcd(m,n)=1即m n 互质或者是(0,1),(1,0)两点.证明很简单,如果gcd(m,n)=d 那么(m/d,n/d)必然会挡住点(m,n),所以gcd(m,n)=1是必然的.这样问题就划归到2到n-1有多少数互质.由于欧拉函数的意义是小于n的与n互质的数的个数,所以知道欧拉函数意义的人都能第一时间想到答案就是t=φ(2)+φ(3)+…+φ(n-1

BZOJ 2190 仪仗队(线性筛欧拉函数)

简化题意可知,实际上题目求得是gcd(i,j)=1(i,j<=n)的数对数目. 线性筛出n大小的欧拉表,求和*2+1即可.需要特判1. # include <cstdio> # include <cstring> # include <cstdlib> # include <iostream> # include <vector> # include <queue> # include <stack> # inclu

bzoj 2190: [SDOI2008]仪仗队.

2190: [SDOI2008]仪仗队 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 3240  Solved: 2092[Submit][Status][Discuss] Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图).现在,C君希望你告诉他队伍整齐时能看到的学生人数. Inp

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

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

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

Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图).现在,C君希望你告诉他队伍整齐时能看到的学生人数. Solution 能被看到的只能是坐标(x,y)x与y互质的学生 观察可以发现1到n-1欧拉phi函数的和*2+1即答案 #include<iostream> #include<cstdio> #include<

【刷题】BZOJ 2190 [SDOI2008]仪仗队

Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图). 现在,C君希望你告诉他队伍整齐时能看到的学生人数. Input 共一个数N. Output 共一个数,即C君应看到的学生人数. Sample Input 4 Sample Output 9 HINT [数据规模和约定] 对于 100% 的数据,1 ≤ N ≤ 40000 Solu

【BZOJ 2190】【SDOI 2008】仪仗队 欧拉筛

欧拉筛模板题 #include<cstdio> using namespace std; const int N=40003; int num=0,prime[N],phi[N]; bool notp[N]; inline void shai(int n){ phi[1]=1; for(int i=2;i<=n;++i){ if (!notp[i]){ prime[++num]=i; phi[i]=i-1; } for(int j=1;j<=num&&i*prime

BZOJ 2190 SDOI 2008 仪仗队 线性欧拉筛

标题效果:有一个格子组件图,假设三个人在一条直线上,那么第一个人将不会看到第三人.现在,有一个人站在(1,1)在.我问他是否能看到n*n的人数的矩阵. 思考:如果你想站(1,1)这名男子看到了一个立场(x,y)一个人.gcd(x,y) == 1,这是一个经典的模型,仅仅要求出n以内phi的和就能够了. 方法就是线性筛. CODE: #include <cstdio> #include <cstring> #include <iostream> #include <

【系列】 莫比乌斯反演

几个有用的结论: 记 $(f*g)(n)=\sum\limits_{d|n} f(d) * g(\frac{n}{d})$ 则有$\mu * 1 = [n=1]$与$\phi *1 = id$ 若$F(n)=\sum\limits_{d|n} f(d)$ 则$f(n)=\sum\limits_{d|n} \mu(d) * F(\frac{n}{d})$ bzoj 2190 仪仗队 题目大意: 求$n*n$的矩形中能从左下角被直接看到的点的个数 思路: 设左下角$(0,0)$ 则相当于求$\sum