#421 Div1 C
#421 Div1 C
题意
在 (0, n) 和 (m, 0) 处各有一个装置,从起始点(0, 0)出发,首先走短路到 (m, 0) 拿起装置回到起始点,再去 (0, n) 处拿起装置回到起始点。当 (m, 0) 处的装置被触碰后,对于后面所有时刻,如果存在某一时刻有一点 (x, y) 和其余两个装置的位置三点组成的三角形面积为s,则计数加1,求最终计数。
分析
- 对于状态 1,即从 \((m, 0)\) 移动到 \((0, 0)\) 的过程,设在 x 轴上移动的坐标为 \((k, 0)\) ,设任意点坐标 \((x, y)\) ,则有 \(((0, n) - (k, 0)) \times ((x, y) - (k, 0)) = 2 * s\) ,作向量叉乘运算。有\(|k*y + n*x - n*k| = 2*s\),如果要求 (x, y) 有整数解,则要求 \(gcd(k, n)|2*s (1 \leq k \leq m)\),对 \(n, k, 2*s\) 分解质因子,设质因子的个数分别为 \(ni, ki, si\) ,如果要满足条件,则对于所有质因子有 \(min(ni, ki) \leq si\),如果 \(ni \leq si\),则 \(ki\) 没有限制,如果 \(ni > si\),则 \(ki \leq si\),可以直接考虑 \(ni > si, ki = si + 1\) 的情况,只要是\(p^{si+1}\)的倍数都是不符合条件,而剩下的都是符合条件的。可以用容斥原理去求。
- 对于状态 2,第一个装置已经在原点\((0, 0)\)了,而第二个装置的位置为\((0, k)\),设任意点坐标 \((x, y)\),向量叉乘运算,有 \((0, k)\times(x, y) = 2*s\),即\(|k*x|=2*s\),对于 \(1 \leq k \leq n\),求 \(k\) 为 \(2*s\) 因子的个数,找到\(2*s\)的素因子及个数,利用 DFS 求解。
code
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MAXN = 1e6 + 5;
ll a[3]; // n m s
ll ans;
int isp[MAXN];
vector<int> prime;
struct factor {
ll x, cnt;
};
vector<factor> fac;
vector<ll> num;
void init() { // 素数筛
memset(isp, 0, sizeof isp);
for(int i = 2; i < MAXN; i++) {
if(!isp[i]) {
prime.push_back(i);
for(ll j = 1LL * i * i; j < (ll)MAXN; j += i) {
isp[j] = 1;
}
}
}
}
vector<factor> getfac(ll x) { // 筛选出质因子及其个数
vector<factor> vec;
for(int i = 0; (ll)prime[i] * prime[i] <= x; i++) {
int c = 0;
while(x % prime[i] == 0) {
c++;
x /= prime[i];
}
if(c) {
vec.push_back(factor{prime[i], c});
}
}
if(x > 1) {
vec.push_back(factor{x, 1});
}
return vec;
}
void dfs1(int pos, ll val, int cnt) { // 容斥
if(pos >= (int)num.size()) {
if(cnt & 1) ans -= a[1] / val;
else ans += a[1] / val;
return;
}
dfs1(pos + 1, val * num[pos], cnt ^ 1);
dfs1(pos + 1, val, cnt);
}
void solve1() { // 状态 1
num.clear();
fac.clear();
fac = getfac(a[0]);
for(int i = 0; i < (int)fac.size(); i++) {
ll sum = 1;
for(int j = 0; j < fac[i].cnt; j++) {
sum *= fac[i].x;
if(a[2] % sum != 0) {
num.push_back(sum);
break;
}
}
}
dfs1(0, 1, 0);
}
void dfs2(int pos, ll val) {
if(pos >= (int)fac.size()) {
ans += (val <= a[0]);
return;
}
ll sum = 1;
for(int i = 0; i <= fac[pos].cnt; i++) {
dfs2(pos + 1, val * sum);
sum *= fac[pos].x;
}
}
void solve2() { // 状态 2
fac.clear();
fac = getfac(a[2]);
dfs2(0, 1);
}
int main() {
int T;
init();
cin >> T;
while(T--) {
ans = 0;
for(int i = 0; i < 3; i++) {
a[i] = 1LL;
for(int j = 0; j < 3; j++) {
ll x;
cin >> x;
a[i] *= x;
}
}
a[2] *= 2;
solve1();
solve2();
cout << ans << endl;
}
return 0;
}
#421 Div1 C的更多相关文章
- CF#345 (Div1)
论蒟蒻如何被cf虐 以下是身败名裂后的题解菌=========== Div1 A.Watchmen 有n个点,每个点有一个坐标.求曼哈顿距离=欧几里得距离的点对数量. 只需要统计x或y一样的点对数量. ...
- 图论 SRM 674 Div1 VampireTree 250
Problem Statement You are a genealogist specializing in family trees of vampires. Vampire famil ...
- jq对象转为dom对象:$(".div1")[0] dom对象转为jq对象:$(dom对象)
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
- 第一次div1做出3道题
第一次div1做出3道题! 再接再厉! 哈利路亚!
- 第一次进div1了
第一次进div1~好激动啊! 上帝依旧那么眷顾我!
- TopCoder 649 div1 & div2
最近一场TC,做得是在是烂,不过最后challenge阶段用一个随机数据cha了一个明显错误的代码,最后免于暴跌rating,还涨了一点.TC题目质量还是很高的,非常锻炼思维,拓展做题的视野,老老实实 ...
- SRM DIV1 500pt DP
SRM 501 DIV1 500pt SRM 502 DIV1 500pt SRM 508 DIV1 500pt SRM 509 DIV1 500pt SRM 511 DIV1 500pt SRM 5 ...
- codeforces #305 div1 done
总算搞定了这一场比赛的题目,感觉收获蛮大 其中A,B,C都能通过自己的思考解决掉 D题思路好神,E题仔细想想也能想出来 以后坚持每两天或者一天做一场CF的div1的全套题目 除非有实在无法做出来的题目 ...
- [Codeforces Round #254 div1] C.DZY Loves Colors 【线段树】
题目链接:CF Round #254 div1 C 题目分析 这道题目是要实现区间赋值的操作,同时还要根据区间中原先的值修改区间上的属性权值. 如果直接使用普通的线段树区间赋值的方法,当一个节点表示的 ...
随机推荐
- PC端网站转换为webApp工具
百度开发云site App:http://siteapp.baidu.com/
- Python 3基础教程3-数学运算
本文来介绍下Python中的常见数学运算,其实和其他语言一样,加减乘除语法差不多,这里注意下Python中指数的表示方法. # 这里介绍 常见的数学运算 # 加法print(5 + 8) # 减法pr ...
- Centos7中查看IP地址命令ifconfig无法识别如何处理
问题描述: 在虚拟机中已安装好Centos7系统,查看IP地址使用命令ifconfig时,提示找不到此命令,使用ip addr命令则可查询当前系统的IP地址(如图1.2): 图1 图2 解决问题步骤: ...
- 用Jenkins自动化搭建测试环境
1-1 课程介绍 2-1 Jenkins安装 2-2 Jenkins插件 2-3 Jenkins基础设置 3-1 Linux系统准备 3-2 安装Java环境 3-3 安装并配置Git 3-4 安装并 ...
- NGUI-UIProgressBar,UIScrollBar,UISlider
UIProgressBar是UIScrollBar和UISlider的基类 1.先来看下UIProgressBar(进度条)的使用 层次: progressBar的Inspector视图: 而fore ...
- Where can I find the IPA logs
Retrieving the IPA logs will differ depending on which base image was used. Operating system that do ...
- 爬虫:Scrapy15 - 调试(Debugging)Spiders
考虑下面的 spider: import scrapy from myproject.items import MyItem class MySpider(scrapy.Spider): name = ...
- 【转】在Unity中读写文件数据:LitJSON快速教程
作者:王选易,出处:http://www.cnblogs.com/neverdie/ 欢迎转载,也请保留这段声明.如果你喜欢这篇文章,请点[推荐].谢谢! 介绍 JSON是一个简单的,但功能强大的序列 ...
- jQuery Ajax(load,post,get,ajax)
1.load(url, [data], [callback]) 载入远程 HTML 文件代码并插入至 DOM 中. 默认使用 GET 方式 - 传递附加参数时自动转换为 POST 方式.jQuery ...
- SOA与WCF
背景: 高校平台马上就要进入编程阶段了,对于没怎么做过正式项目的我们来说,要学的东西实在太多了.一下子面对这么多学习资料时,我们也不能着急,还是踏踏实实,一个一个地去了解,其实他们都没那么神秘.这篇博 ...