【魔改】莫队算法+组合数公式 杭电多校赛4 Problem B. Harvest of Apples
http://acm.hdu.edu.cn/showproblem.php?pid=6333
莫队算法是一个离线区间分块瞎搞算法,只要满足:1.离线 2.可以O(1)从区间(L,R)更新到(L±1,R±1)就能直接套板子了
这道题不是区间算法,但是有递推式:
把它看成区间更新orz
所以可以莫队orz
- #define _CRT_SECURE_NO_WARNINGS
- #include <cmath>
- #include <iostream>
- #include <stdio.h>
- #include<algorithm>
- #include <map>
- #include <cstring>
- #include <time.h>
- using namespace std;
- #define rep(i,t,n) for(int i =(t);i<=(n);++i)
- #define per(i,n,t) for(int i =(n);i>=(t);--i)
- #define mmm(a,b) memset(a,b,sizeof(a))
- const int maxn = 1e5 + ;
- const long long mod = 1e9 + ;
- map<int, int> mmp;
- typedef long long ll;
- struct node {
- int l, r, id;
- }Q[maxn];
- ll fac[maxn], infac[maxn];
- long long ans[maxn];
- long long num[maxn];
- int a[maxn], pos[maxn];
- int n, m, k;
- int L = , R = ;
- long long Ans = ;
- ll cal(ll x) {
- ll res = ;
- int k = mod - ;
- while (k) {
- if (k & ) {
- res *= x;
- res %= mod;
- }
- x *= x;
- x %= mod;
- k >>= ;
- }
- return res;//cal(x^ mod)
- }
- void init() {
- fac[] = ;
- rep(i, , maxn - )fac[i] = (fac[i-] * i)%mod;
- rep(i, , maxn - )infac[i] = cal(fac[i]);
- }
- ll C(ll a, ll b)
- {
- return 1ll * fac[a] * infac[b] % mod * infac[a - b] % mod;
- }
- bool cmp(node a, node b) {
- if (pos[a.r] == pos[b.r])
- return a.l < b.l;
- return pos[a.r] < pos[b.r];
- }
- void add(int x) {
- //num[a[x]]++;
- //if (num[a[x] - 1] == 0 && num[a[x] + 1] == 0)Ans++;
- //else if (num[a[x] - 1] && num[a[x] + 1])Ans--;
- Ans += C(n, m);
- }
- void addl(int x) {
- }
- void del(int x) {
- //num[a[x]]--;
- //if (num[a[x] - 1] == 0 && num[a[x] + 1] == 0)Ans--;
- //else if (num[a[x] - 1] && num[a[x] + 1])Ans++;
- Ans -= C(n, m + );
- }
- int smain() {
- int t; scanf("%d", &t);
- init();
- Ans = ;
- mmm(num, );
- L = , R = ;
- int sz = sqrt(1e5);
- for (int i = ; i <= 1e5; i++) {
- pos[i] = i / sz;
- }
- rep(i,,t) {
- scanf("%d%d", &Q[i].l, &Q[i].r);
- Q[i].id = i;
- }
- sort(Q + , Q + + t, cmp);
- Ans = ;//S(m,n
- L = Q[].l; R = -;
- rep(i,,t){
- while (L < Q[i].l) {
- //del(L);
- Ans = (2ll * Ans - C(L, R) + mod) % mod;
- ++L;
- }
- while (L > Q[i].l) {
- --L;
- //addl(L);
- Ans = ((Ans + C(L, R)) *infac[]%mod) % mod;
- }
- while (R < Q[i].r) {
- ++R;
- //add(R);
- Ans = (Ans+C(L, R))%mod;
- }
- while (R > Q[i].r) {
- //del(R);
- Ans = (Ans-C(L, R)+mod)%mod;
- --R;
- }
- ans[Q[i].id] = Ans;
- }
- rep(i,,t)printf("%lld\n", ans[i]);
- return ;
- }
- /*
- 6
- 60522 25373
- 36426 3283
- 48772 42553
- 33447 12441
- 3497 2182
- 7775 4025
- */
- #define ONLINE_JUDGE
- int main() {
- //ios::sync_with_stdio(false);
- #ifndef ONLINE_JUDGE
- FILE *myfile;
- myfile = freopen("C:\\Users\\acm-14\\Desktop\\test\\b.in", "r", stdin);
- if (myfile == NULL)
- fprintf(stdout, "error on input freopen\n");
- FILE *outfile;
- outfile = freopen("C:\\Users\\acm-14\\Desktop\\test\\out.txt", "w", stdout);
- if (outfile == NULL)
- fprintf(stdout, "error on output freopen\n");
- long _begin_time = clock();
- #endif
- smain();
- #ifndef ONLINE_JUDGE
- long _end_time = clock();
- printf("time = %ld ms.", _end_time - _begin_time);
- #endif
- cin >> n;
- return ;
- }
【魔改】莫队算法+组合数公式 杭电多校赛4 Problem B. Harvest of Apples的更多相关文章
- 【题解】BZOJ4241: 历史研究(魔改莫队)
[题解]BZOJ4241: 历史研究(魔改莫队) 真的是好题啊 题意 给你一个序列和很多组询问(可以离线),问你这个区间中\(\max\){元素出现个数\(\times\)元素权值} IOI国历史研究 ...
- 可持久化线段树的学习(区间第k大和查询历史版本的数据)(杭电多校赛第二场1011)
以前我们学习了线段树可以知道,线段树的每一个节点都储存的是一段区间,所以线段树可以做简单的区间查询,更改等简单的操作. 而后面再做有些题目,就可能会碰到一种回退的操作.这里的回退是指回到未做各种操作之 ...
- HDU 6278 - Just h-index - [莫队算法+树状数组+二分][2018JSCPC江苏省赛C题]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6278 Time Limit: 6000/3000 MS (Java/Others) Memory Li ...
- 【莫队算法】【权值分块】bzoj3339 Rmq Problem
如题. #include<cstdio> #include<algorithm> #include<cmath> using namespace std; #def ...
- hdu 5373 The shortest problem(杭电多校赛第七场)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5373 The shortest problem Time Limit: 3000/1500 MS (J ...
- hdu 5328 Problem Killer(杭电多校赛第四场)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5328 题目大意:找到连续的最长的等差数列or等比数列. 解题思路:1.等差等比的性质有很多.其中比较重 ...
- hdu 5319 Painter(杭电多校赛第三场)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5319 Painter Time Limit: 2000/1000 MS (Java/Others) ...
- hdu 5326 Work(杭电多校赛第三场)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5326 Work Time Limit: 2000/1000 MS (Java/Others) M ...
- 2019杭电多校赛第九场 Rikka with Mista
Problem Description Rikka is a fervent fan of JoJo's Bizarre Adventure. As the last episode of Golde ...
随机推荐
- android 性能优化-工具篇
一.Traceview 使用TraceView主要有两种方式: 1.直接打开DDMS,选择一个进程,然后按上面的“Start Method Profiling”按钮,等红色小点变成黑色以后就表示Tra ...
- 【Java】Java Queue的简介
阻塞队列 阻塞队列有几个实现: ArrayBlockingQueue LinkedBlockingQueue PriorityBlockingQueue DelayQueue SynchronousQ ...
- sqlmap tamter
支持的数据库 编号 脚本名称 作用 实现方式 all 1 apostrophemask.py 用utf8代替引号 ("1 AND '1'='1") '1 AND %EF%BC%87 ...
- NodeJS的url验证库模块url-valid
这是我10月份做的项目其中的一个部件,主要用于url检验的. 我们知道Javascript做url检验,通常是使用正则表达式来判定,其格式是否正确,例如: /^https?:\/\//.test(ur ...
- mysql 修改表的每个列的字符类型
#!/bin/shfor i in $(mysql -uroot -p112358s uarticles_2019 -e "show tables;"|egrep -v Table ...
- Jenkins这种构建工具,一般都是内部使用,所以外部基本上不能访问
类似于Jenkins这种构建工具,一般都是内部使用,所以外部基本上不能访问,也可以隔绝外部黑客的入侵等.直接暴露外部是非常不安全的,特别是没有什么安全验证,容易被别人入侵做一些非法的事情! 所以,希望 ...
- 【SpringMVC学习07】SpringMVC中的统一异常处理
我们知道,系统中异常包括:编译时异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生.在开发中,不管是dao层 ...
- CSS实现响应式全屏背景图
body { /* 加载背景图 */ background-image: url(images/background-photo.jpg); /* 背景图垂直.水平均居中 */ background- ...
- psd页面切割成html技巧总结
关键字:psd切割技巧 生成html图片要点 css样式要点 rem 与高手切割后的代码对比学习提高(考察点:切割后的页面质量,源码大小及图片大小,js技术,动画技术,开发和命名规范等) 一.psd切 ...
- Rest风格理解
之前一直不理解restful风格,今天终于理解了些(20170527) 正常我们在浏览器的地址栏中输入的地址很多都是发起的,发起的都是get请求 通过ajax可以设置put请求,F12查看浏览器请求头 ...