1678 lyk与gcd 

基准时间限制:2 秒 空间限制:131072 KB 分值: 80 难度:5级算法题

 收藏

 关注

这天,lyk又和gcd杠上了。

它拥有一个n个数的数列,它想实现两种操作。

1:将  ai 改为b。

2:给定一个数i,求所有 gcd(i,j)=1 时的  aj  的总和。

Input

第一行两个数n,Q(1<=n,Q<=100000)。
接下来一行n个数表示ai(1<=ai<=10^4)。
接下来Q行,每行先读入一个数A(1<=A<=2)。
若A=1,表示第一种操作,紧接着两个数i和b。(1<=i<=n,1<=b<=10^4)。
若B=2,表示第二种操作,紧接着一个数i。(1<=i<=n)。

Output

对于每个询问输出一行表示答案。

Input示例

5 3
1 2 3 4 5
2 4
1 3 1
2 4

Output示例

9
7

看了讨论区才会做。。。

#include<bits/stdc++.h>

using namespace std;

const int MAX_N=1000051;

int prime[MAX_N];//素数表

bool is_prime[MAX_N+1];

//返回n以内的素数的个数

int sieve(int n)

{

    int p=0;

    for(int i=0;i<=n;i++)is_prime[i]=true;

    is_prime[0]=is_prime[1]=false;

    for(int i=2;i<=n;i++)

    {

        if(is_prime[i])

        {

            prime[p++]=i;//素数打表

            for(int j=2*i;j<=n;j+=i)is_prime[j]=false;//去掉已有素数的倍数

        }

    }

    return p;

}

int n,q;

int a[100005];

int A;

int sum=0;

int primecnt;

int val[100005];//val [x] = y 表示对于含有x因子的下标的数值总和为y

vector<int>v;

void update(int x,int y)//更新

{

    sum-=a[x];

    for(int i=1;i*i<=x;i++)

    {

        if(x%i==0)

        {

            if(i*i!=x)

            val[x/i]+=y-a[x];

            val[i]+=y-a[x];

        }

    }

    a[x]=y;

    sum+=a[x];

}

void getprime(int n)//素因子分解

{

    v.clear();

    int temp,i,now;

    temp=(int)((double)sqrt(n)+1);

    now=n;

    for(i=2;i<=temp;++i)if(now%i==0){

        v.push_back(i);

        while(now%i==0){

            now/=i;

        }

    }

    if(now!=1){

        v.push_back(now);

    }

}

int query(int x)

{

    getprime(x);

    int res=0,len=v.size();

    for(int i=1;i<(1<<len);i++)//枚举所有非空子集

    {

        int cnt=0,t=1;

        for(int j=0;j<len;j++)

        {

            if(i&(1<<j))

            {

                t*=v[j];

                cnt++;

            }

        }

        //容斥原理计数,若集合大小为奇数,则加上,否则减掉

        if(cnt&1)

        res+=val[t];

        else

        res-=val[t];

    }

    return res;

}

int main()

{

    #ifndef ONLINE_JUDGE

        freopen("in.txt","r",stdin);

    #endif // ONLINE_JUDGE

        primecnt=sieve(1000050);

      scanf("%d%d",&n,&q);

      for(int i=1;i<=n;i++)

      {

          scanf("%d",&a[i]);sum+=a[i];

      }

//初始化val数组

      for(int i=1;i<=n;i++)

        for(int j=1;i*j<=n;j++)

            val[i]+=a[i*j];

int i,b;int ans=0;

      while(q--)

      {

          scanf("%d",&A);

          if(A==1)

          {

              scanf("%d%d",&i,&b);

              update(i,b);

          }

          else

          {

              scanf("%d",&i);

              ans=query(i);

              printf("%d\n",sum-ans);

          }

      }

}

51 Nod 1678 lyk与gcd(容斥原理)的更多相关文章

  1. 51 Nod 1678 lyk与gcd

    1678 lyk与gcd 基准时间限制:2 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 这天,lyk又和gcd杠上了.它拥有一个n个数的数列,它想实现两种操作. 1:将  ai  ...

  2. 51nod 1678 lyk与gcd | 容斥原理

    51nod 200题辣ψ(`∇´)ψ !庆祝! 51nod 1678 lyk与gcd | 容斥原理 题面 这天,lyk又和gcd杠上了. 它拥有一个n个数的数列,它想实现两种操作. 1:将 ai 改为 ...

  3. 1678 lyk与gcd

    1678 lyk与gcd 基准时间限制:2 秒 空间限制:131072 KB 这天,lyk又和gcd杠上了.它拥有一个n个数的数列,它想实现两种操作. 1:将  ai 改为b.2:给定一个数i,求所有 ...

  4. [51nod]1678 lyk与gcd(莫比乌斯反演)

    题面 传送门 题解 和这题差不多 //minamoto #include<bits/stdc++.h> #define R register #define pb push_back #d ...

  5. 51nod lyk与gcd

    1678 lyk与gcd 基准时间限制:2 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 这天,lyk又和gcd杠上了.它拥有一个n个数的数列,它想实现两种操作. 1:将  ai  ...

  6. 51nod1678 lyk与gcd

    容斥定理所以可以用莫比乌斯函数来搞.逆向思维答案等于总和减去和他互质的.那么设f[i]=∑a[j] i|j.ans[i]=sum- ∑mo[j]*f[j] 跟bzoj2440那道题挺像的都是利用莫比乌 ...

  7. 51 nod 1439 互质对(Moblus容斥)

    1439 互质对 题目来源: CodeForces 基准时间限制:2 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 有n个数字,a[1],a[2],…,a[n].有一个集合,刚开 ...

  8. 51 nod 1610 路径计数(Moblus+dp)

    1610 路径计数 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题   路径上所有边权的最大公约数定义为一条路径的值. 给定一个有向无环图.T次修改操作,每次修改一 ...

  9. 51 nod 1188 最大公约数之和 V2

    1188 最大公约数之和 V2 题目来源: UVA 基准时间限制:2 秒 空间限制:262144 KB 分值: 160 难度:6级算法题   给出一个数N,输出小于等于N的所有数,两两之间的最大公约数 ...

随机推荐

  1. Java第六周实验+总结

    一.实验目的 (1)掌握类的继承 1.子类继承父类中非private的成员变量和成员方法,同时,注意构造方法不能被子类继承. 2.定义类时若缺省extends关键字,则所定义的类为java.lang. ...

  2. 思考--PostgreSQL在与mysql的比较中稍微弱势项

    PostgreSQL在与mysql的比较中稍微弱势项: 1.都是堆表,没有所谓的聚集索引表,其实问题不大,聚集索引表也只是在使用聚集索引那些列有加速,而且pg也有聚集索引,只不过要定期重建. 2.mv ...

  3. 如何实现Java线程的 阻塞/唤醒(和暂停/继续 类似)

    以下为线程 阻塞/唤醒  主要代码 public class MyThread extends Thread { //无意义 private final Object lock = new Objec ...

  4. A*算法【拼图游戏】

    数据结构 using System; using System.Collections.Generic; using System.Linq; using System.Text; using Sys ...

  5. python3抓取中国天气网不同城市7天、15天实时数据

    思路:1.根据city.txt文档来获取不同城市code2.获取中国天气网7d和15d不同城市url3.利用requests库请求url获取html内容4.利用beautifulsoup获取7d和15 ...

  6. inline void 树状数组神奇感悟【雾

    才发现扫描线可以用树状数组搞... 致远星患者 (另外根据这篇博文的内容怎么越来越感觉自己往 PJ 入门靠拢了...) 还有一点,咱把树状数组当做线段树来康的话其实一切都会很清晰,这个来张四合一的图: ...

  7. ORA-00979: 不是 GROUP BY 表达式

    在oracle数据库中,sql语句中group by子句报错,原因是select 存在列字段,而group by中不存在.

  8. 【总结】Android 应用测试总结

    前提 所有的功能分支已完成 启动: 1. 启动入口:桌面正常启动,最近运行启动,所有程序列表中启动,锁屏快捷启动2. 其他入口:从其他程序开启应用,从外部以文件形式打开应用(如果有)3. 退回:从其他 ...

  9. 三种动态加载js的jquery实例代码另附去除js方法

    !-- 这里为你提供了三种动态加载js的jquery实例代码哦,由于jquery是为用户提供方便的,所以利用jquery动态加载文件只要一句话$.getscript("test.js&quo ...

  10. (转)linux chattr lsattr 命令

    转http://www.ha97.com/5172.html PS:有时候你发现用root权限都不能修改某个文件,大部分原因是曾经用chattr命令锁定该文件了.chattr命令的作用很大,其中一些功 ...