题解-The Number of Good Intervals
题面
给定 \(n\) 和 \(a_i(1\le i\le n)\),\(m\) 和 \(b_j(1\le j\le m)\),求对于每个 \(j\),\(a_i\) 区间 \(\gcd\) 为 \(b_j\) 的区间数。
数据范围:\(1\le n\le 4\cdot 10^6\),\(1\le m\le 2\cdot 10^5\),\(1\le a_i,b_i\le 4\cdot 10^4\)。
解法
唠叨
蒟蒻考场上 \(\Theta(n{\rm d}(a))\) 的公约数容斥过了……赛后 \(\tt MLE\#13\)。
正解有好多种,都是 \(\Theta(n\log^2n+m)\) 的,其中一个 \(\log\) 来自 \(\gcd\)。蒟蒻说说最妙的一种。
奇妙的正解
\(f_{i,j}\) 表示右端点为 \(i\),\(\gcd\) 为 \(j\) 的区间数。
\]
当然要考虑区间 \([i,i]\),\(f_{i,a_i}++\)。
然后 \(i\) 这维滚动掉,\(j\) 这维用哈希表。
时间复杂度 \(\Theta(n\log^2n+m)\)。
- 证明:
只考虑 \(f_{i,j}>0\) 的 \(j\),如果有 \(cnt\) 种,如果要加 \(1\) 种不减少原来的 \(cnt\) 种,必须是原来 \(cnt\) 种的公倍数。所以任何时候,\(cnt\) 必然是 \(\log\) 级别的。
然后 \(ans_j=\sum_{i=1}^n f_{i,j}\),可以求 \(f\) 的时候一起求,每次查询 \(\Theta(1)\)。
代码
#include <bits/stdc++.h>
using namespace std;
//Start
typedef long long ll;
typedef double db;
#define mp(a,b) make_pair(a,b)
#define x first
#define y second
#define be(a) a.begin()
#define en(a) a.end()
#define sz(a) int((a).size())
#define pb(a) push_back(a)
const int inf=0x3f3f3f3f;
const ll INF=0x3f3f3f3f3f3f3f3f;
//Data
const int N=4e6,A=4e4;
int n,m; ll ans[A+1];
unordered_map<int,ll> hsh[2];
int gcd(int x,int y){return x?gcd(y%x,x):y;}
//Main
int main(){
	ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	cin>>n;
	int now=1,a;
	while(n--){
		cin>>a,now^=1,hsh[now].clear();
		for(auto it:hsh[now^1]){
			int g=gcd(a,it.x);
			hsh[now][g]+=it.y,ans[g]+=it.y;
		}
		hsh[now][a]++,ans[a]++;
	}
	cin>>m;
	int b;
	while(m--){
		cin>>b;
		cout<<ans[b]<<'\n';
	}
	return 0;
}
祝大家学习愉快!
题解-The Number of Good Intervals的更多相关文章
- 竞赛题解 - Karp-de-Chant Number(BZOJ-4922)
		Karp-de-Chant Number(BZOJ-4922) - 竞赛题解 进行了一次DP的练习,选几道题写一下博客~ 标签:BZOJ / 01背包 / 贪心 『题目』 >> There ... 
- leetcode题解 200. Number of Islands(其实就是一个深搜)
		题目: Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is s ... 
- LeetCode题解——Palindrome Number
		题目: 判断一个数字是不是回文数字,即最高位与最低位相同,次高位与次低位相同,... 解法: 求出数字的位数,然后依次求商和求余判断是否相等. 代码: class Solution { public: ... 
- LeetCode题解之Number of Segments in a String
		1.题目描述 2.题目分析 找到字符串中的空格即可 3.代码 int countSegments(string s) { ){ ; } vector<string> v; ; i < ... 
- LeetCode 题解之Number Complement
		1.题目描述 2.题目分析 使用 C++的 bitset 库进行操作: 3.代码 int findComplement(int num) { bitset<> b(num); string ... 
- LeetCode题解之Number of 1 Bits
		1.题目描述 2.问题分析 使用C++ 标准库的 bitset 类,将整数转换为 二进制,然后将二进制表示转换为字符串,统计字符串中 1 的个数即可. 3.代码 int hammingWeight(u ... 
- leetCode题解之Number of Lines To Write String
		1.题目描述 2.分析 使用一个map将字母和数字对应起来,方便后续使用. 3.代码 vector<int> numberOfLines(vector<int>& wi ... 
- leetcode题解||Palindrome Number问题
		problem: Determine whether an integer is a palindrome. Do this without extra space. click to show sp ... 
- [LeetCode] Data Stream as Disjoint Intervals 分离区间的数据流
		Given a data stream input of non-negative integers a1, a2, ..., an, ..., summarize the numbers seen ... 
随机推荐
- mysql 常用命令和笔记
			第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ... 
- 考研党其实可以用思维导图MindManager做考研复习计划
			近年由于就业压力,个人学历提升等各种原因,考研的人数越来越多了,相对难度也越来越大了,尽管今年研究生招生规模同比去年增加18.9万,但也无法掩盖考研的竞争逐年激烈. 身为考研大军中的预备选手之一,小编 ... 
- 【ES6】ES6入门笔记
			1.概要 - ECMAScript2015(ES6)是Javascript最标准的语法式样,是在2015年6月由Ecma国籍组织公布的最新版本,现在已经被多个领域和浏览器所广泛采纳和使用. 2.学习网 ... 
- jQuery 根据value设置radio默认选中
			jQuery 根据value设置radio默认选中:HTML: <input type="radio" name="type" value="1 ... 
- iOS中字符串转float类型失真的解决办法
			最近在做项目的过程中,偶然遇到了一个问题,就是字符串和浮点类型的转换.以往都是通过[NSString stringWithFormat:@"%d",goodcount]这种方式转换 ... 
- iPhone/iOS开启个人热点的相关位置调整小结
			冬至已到,圣诞将近,最近公司项目实在太多,三四个项目反复的切换真的让人焦头烂额,趁今天有点空,把维护的三个项目顺利送出,刚好可以缕缕思路,记录一下最近遇到的问题.说不着急那是假的,客户一天天的催的确实 ... 
- 关于UILabel标签控件的使用小节
			前段时间一直想停下来,总结一下近期在开发中遇到的一些问题顺便分享一下解决问题的思路和方法,无奈人生就像蒲公英,看似自由却身不由己.太多的时间和精力被占用在新项目的开发和之前项目的维护中,总之一句话外包 ... 
- C语言讲义——库函数排序qsort
			qsort函数在在stdlib.h中. 函数原型 void qsort(void *base, size_t nitems, size_t size, int (*compar)(const void ... 
- redis 做分布式锁
			ok 我们从最基础的一步步来 加锁: 1.setNx没有expire,拿锁线程挂掉后,死锁 2.setNx然后exipre分两步做,setNx后redis宕机,或者线程挂掉,死锁 3.SETNX re ... 
- DNS、IP地址、子网掩码和默认网关
			一.DNS服务器 DNS是指:域名服务器(Domain Name Server).在Internet上域名与IP地址之间是一一对应的,域名虽然便于人们记忆,但机器之间只能互相认识IP地址,它们之间的转 ... 
