题目地址:https://www.nowcoder.com/acm/contest/136/F

树状数组、快速幂、逆元的模板运用;

  1. #include<iostream>
  2. #include<cstdio>
  3. using namespace std;
  4.  
  5. #define LL long long
  6. #define lowbit(x) x&-x
  7. const int N = 1e6+;
  8. const LL MOD = 1e9+;
  9. int n, m;
  10. LL sum[N];
  11.  
  12. void read(int &x) {
  13. int f = ; x = ;
  14. char ch = getchar();
  15.  
  16. while (ch < '' || ch > '') {if (ch == '-') f = -; ch = getchar();}
  17. while (ch >= '' && ch <= '') {x = x * + ch - ''; ch = getchar();}
  18. x *= f;
  19. }
  20.  
  21. LL quick_pow(LL a, LL k)
  22. {
  23. LL tmp=;
  24. while(k) {
  25. if(k&)
  26. tmp = tmp*a%MOD;
  27. a = a*a%MOD;
  28. k>>=;
  29. }
  30. return tmp;
  31. }
  32.  
  33. LL find(LL b)
  34. {
  35. LL sum1=;
  36. for(int i=b; i; i-=lowbit(i))
  37. sum1 = sum1*sum[i]%MOD;
  38. return sum1;
  39. }
  40.  
  41. int main()
  42. {
  43. read(n); read(m);
  44. for(int i=; i<=n; i++) sum[i]=;
  45.  
  46. for(int x,y,z,t=; t<m; t++) {
  47. read(x); read(y); read(z);
  48.  
  49. if(x == ) {
  50. for(int i=y; i<=n; i+=lowbit(i))
  51. sum[i] = sum[i]*z%MOD;
  52. }
  53. else if(x == ) {
  54. LL inv = quick_pow(z, MOD-);
  55. for(int i=y; i<=n; i+=lowbit(i))
  56. sum[i] = sum[i]*inv%MOD;
  57. }
  58. else if(x == ) {
  59. LL ans = find(z)*quick_pow(find(y-), MOD-);
  60. ans = (ans%MOD + MOD)%MOD;
  61. printf("%lld\n", ans);
  62. }
  63. }
  64.  
  65. return ;
  66. }

【牛客小白月赛6】F 发电 - 树状数组&快速幂&逆元的更多相关文章

  1. 牛客小白月赛6 F 发电 树状数组单点更新 求区间乘积 模板

    链接:https://www.nowcoder.com/acm/contest/136/F来源:牛客网  HA实验是一个生产.提炼“神力水晶”的秘密军事基地,神力水晶可以让机器的工作效率成倍提升.   ...

  2. 牛客小白月赛12 F 华华开始学信息学 (分块+树状数组)

    链接:https://ac.nowcoder.com/acm/contest/392/F来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 32768K,其他语言65536K ...

  3. 牛客练习赛52 B题【树状数组维护区间和{查询区间和,如果区间元素重复出现则计数一次}】补题ing

    [题目] 查询区间和,如果区间元素重复出现则计数一次. 链接:https://ac.nowcoder.com/acm/contest/1084/B [题解] 将询问按r排序,维护每个数最后出现的位置, ...

  4. 牛客小白月赛16 F 小石的妹子 (线段树)

    链接:https://ac.nowcoder.com/acm/contest/949/F来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...

  5. 牛客小白月赛3 F 异或【区间交集】

    链接:https://www.nowcoder.com/acm/contest/87/F 来源:牛客网 题目描述 Cwbc想测试一下他的加密协议,以便防止其他人偷看他给XHRlyb的信. Cwbc提出 ...

  6. 牛客网 牛客小白月赛1 F.三视图

    F.三视图   链接:https://www.nowcoder.com/acm/contest/85/F来源:牛客网     这个题自己想一下三维的,正视图和左视图中y轴为行数,x轴和z轴是列数,因为 ...

  7. 牛客小白月赛1 F 三视图 【循环】

    题目链接 https://www.nowcoder.com/acm/contest/85/F 思路 记录每一个面 上的点 是否有方块 然后 根据它的输出顺序 遍历访问 如果有 输出 'X' 否则 输出 ...

  8. 牛客小白月赛5 F 圆(circle) 【欧拉定理】

    题目连接: https://www.nowcoder.com/acm/contest/135/F 签到题来了,送你们一个Python秒的题. Apojacsleam来到了OI大陆,经过了连年征战,成为 ...

  9. 牛客小白月赛9 A签到(分数取模,逆元)

    传送门 对分母求一下逆元,把除法取模变成乘法取模,逆元介绍看这里 这种方法只适合模为质数的情况 #include<bits/stdc++.h> using namespace std; ; ...

随机推荐

  1. 我的Android笔记(十)—— ProgressDialog的简单应用,等待提示 (转载)

    转自:http://blog.csdn.net/barryhappy/article/details/7376231 在应用中经常会用到一些费时的操作,需要用户进行等待,比如加载网页内容…… 这时候就 ...

  2. E20170405-gg

    repository n. 存储库,知识库 Permanent adj 永久的 host      n 主机,住处人,主人 authenticate v 使生效,验证 shell n 外壳 commi ...

  3. lightoj1079【背包】

    题意: 哈利波特抢银行... 给出n个银行,每个银行有a[i]百万和b[i]的风险.然后再给一个风险值P,不能超过P. 思路: 如果告诉你概率的小数的位数,可能这个就会不一样了... 慨率的计算,风险 ...

  4. POJ2446【建图建图】

    题意: 给你一个n*n的矩阵,然后再给你几个坑,然后问你能否被1*2的长方形给覆盖: -弱知道了是二分匹配的做法,但是弱还是不会转化,又是在建图上GG了 分析: 从国际象棋的那个黑白色理解,这是一张二 ...

  5. .NET Core 跨平台物联网开发:连接阿里云IOT(一)

    系列教程目录 (一) 连接阿里云IOT (二) 设置委托事件 (三) 上报属性 (四)  SDK文档 属性.方法.委托.类 http://pan.whuanle.cn/index.php?dir=up ...

  6. 【loj10061】最短母串

    #10061. 「一本通 2.4 练习 4」最短母串 内存限制:512 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 上传者: 1bentong 提交    提交 ...

  7. Folding UVA - 1630

    题目 ans[i][j]表示由原串第i个字符到第j个字符组成的子串的最短折叠长度如果从i到j本身可以折叠,长度就是本身长度或折叠后的长度的最小值***此处参考:http://blog.csdn.net ...

  8. SPFA/Dijkstra POJ 3013 Big Christmas Tree

    题目传送门 题意:找一棵树使得造价最少,造价为每个点的子节点造价和*边的造价和 分析:最短路跑出1根节点到每个点的最短边权值,然后每个点的权值*最短边距和就是答案,注意INF开足够大,n<=1特 ...

  9. php输出中文字符

    中文字符不可以使用imagettftext()函数在图片中直接输出,如果要输出中文字符,需要先使用iconv()函数对中文字符进行编码,语法格式如下:string iconv ( string $in ...

  10. 记录两个python itchat的用法博客网址

    http://www.tuicool.com/articles/VJZRRfn https://itchat.readthedocs.io/zh/latest/