codevs 1213 解的个数
1213 解的个数
已知整数x,y满足如下面的条件:
ax+by+c = 0
p<=x<=q
r<=y<=s
求满足这些条件的x,y的个数。
第一行有一个整数n(n<=10),表示有n个任务。n<=10
以下有n行,每行有7个整数,分别为:a,b,c,p,q,r,s。均不超过108。
共n行,第i行是第i个任务的解的个数。
2
2 3 -7 0 10 0 10
1 1 1 -10 10 -9 9
1
19
分类标签 Tags 点此展开
神坑啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊
以下内容摘自某大神的题解
1.首先我们可以很直观地看出来这是用扩展欧几里得算法解二元一次方程,但问题是我们所熟悉的扩欧能解的方程都是ax+by=gcd(a,b)形式的,而题目给出的是ax+by=-c形式。举个例子:
2x+4y=18,首先我们可以换成x+2y=9形式。9不是2和4的最大公约数1,但9是1的倍数,所以如果我们解出一组x,y满足x+2y=1,那么x和y都乘上9/1就是原方程的一组解了。如果c/gcd(a,b)==0,那么就没有整数解。
2.如今我们得到了一组x,y,根据扩欧定理的后续内容,适合的解系一定是(x+bk,y-ak),注意现在的a,b是简化后的方程的系数(拿上面提到的例子讲,现在a=1,b=2),枚举找在区间内的解的个数(组数)就好。
3.现在解决各种WA/TLE/RE问题:
(1)方程无解:c/gcd(a,b)==0,直接输出0;
(2)区间不合法:题目中没有保证区间左端点小于右端点,所以如果读入的区间不合法,直接输出0;
(3)a=0或b=0:
if((a==0)&&(y<r||y>s)) {printf("0\n");continue;}
if((b==0)&&(x<p||x>q)) {printf("0\n");continue;}
因为不管加多少,x/y还是原来的味道……但是如果不加特判可能会导致TLE(这个跟代码具体的写法有关,我后面有用while循环,直接卡T了)
(4)a==0&&b==0:
RE的关键所在,因为gcd求出来是0……这个需要认真思考一下,如果c!=0,显然方程不成立,无解;如果c==0,x和y就可以任意取了,由乘法原理可得解的个数就是两个区间内部整数点的个数的乘积
if (c!=0)printf("0\n");
else
{
ll cnt=(q-p+1)*(s-r+1);
printf("%lld\n",cnt);
}
continue;
(5)记得要开long long
两个神坑的数据点:
4
0 1 2 0 0 0 2
1 0 2 0 0 0 0
1 0 2 0 2 0 20
2 0 3 -10 10 -10 10
ans:0 0 0 0
4
0 0 0 -1 1 -1 1
0 0 0 1 -1 1 2
0 0 1 1 1 1 1
0 0 0 -3406792423987599 -23487749 23947250
ans:9 0 0 2753863780940000
#include<iostream>
#include<cstdio>
using namespace std;
long long int x,y;
long long int tot=;
long long int a,b,c,p,q,r,s;
long long int gcd(long long int a,long long int b)
{
if(b==)
return a;
else
return gcd(b,a%b);
}
long long int exgcd(long long int a,long long int b,long long int & x,long long int & y)
{
if(b==)
{
x=;
y=;
return a;
}
long long int r=exgcd(b,a%b,x,y);
long long int tmp;
tmp=x;
x=y;
y=tmp-a/b*y;
return r;
}
int main()
{ int n;
scanf("%d",&n);
for(int i=;i<=n;i++)
{
tot=;
//scanf("%lld %lld %lld %lld %lld %lld %lld",&a,&b,&c,&p,&q,&r,&s);
cin>>a>>b>>c>>p>>q>>r>>s;
c=-c;
if((a==)&&(y<r||y>s))
{
printf("0\n");
continue;
}
if((b==)&&(x<p||x>q))
{
printf("0\n");
continue;
} if(p>q||r>s)
{
cout<<<<endl;
continue;
} int gys=gcd(a,b);
if(gys==)
{
if (c!=)
{
printf("0\n");
continue;
}
else
{
tot=(q-p+)*(s-r+);
printf("%lld\n",tot);
continue;
}
}
if(c%gys!=)
{
cout<<<<endl;
continue;
}
exgcd(a,b,x,y);
x=x*(c/gys);
y=y*(c/gys);
a=a/gys;
b=b/gys;
while(x>=p)
{
x=x-b;
y=y+a;
}
while(x<p&&b!=)
{
x=x+b;
y=y-a;
}
while(x>=p&&x<=q&&y>=r&&y<=s)
{
tot++;
x=x+b;
y=y-a;
if(x<p||x>q||y<r||y>s)
break;
}
printf("%lld\n",tot);
} return ;
}
codevs 1213 解的个数的更多相关文章
- 扩展gcd codevs 1213 解的个数
codevs 1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x,y满足如下面的条件: ax+by ...
- Codevs 1213 解的个数(exgcd)
1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x,y满足如下面的条件: ax+by+c=0 p< ...
- codevs 1213 解的个数(我去年打了个表 - -)
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int T,x ...
- 解的个数(codevs 1213)
题目描述 Description 已知整数x,y满足如下面的条件: ax+by+c = 0 p<=x<=q r<=y<=s 求满足这些条件的x,y的个数. 输入描述 Input ...
- n元线性方程非负整数解的个数问题
设方程x1+x2+x3+...+xn = m(m是常数) 这个方程的非负整数解的个数有(m+n-1)!/((n-1)!m!),也就是C(n+m-1,m). 具体解释就是m个1和n-1个0做重集的全排列 ...
- codevs1213 解的个数
题目描述 Description 已知整数x,y满足如下面的条件: ax+by+c = 0 p<=x<=q r<=y<=s 求满足这些条件的x,y的个数. 输入描述 Input ...
- P1098 方程解的个数
题目描述 给出一个正整数N,请你求出x+y+z=N这个方程的正整数解的组数(1<=x<=y<=z<1000).其中,1<=x<=y<=z<=N . 输入 ...
- HDU1573 线性同余方程(解的个数)
X问题 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- CODEVS——T1979 第K个数
http://codevs.cn/problem/1979/ 时间限制: 1 s 空间限制: 1000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descript ...
随机推荐
- Pycharm新手教程,只需要看这篇就够了
pycharm是一款高效的python IDE工具,它非常强大,且可以跨平台,是新手首选工具!下面我给第一次使用这款软件的朋友做一个简单的使用教程,希望能给你带来帮助! 目前pycharm一共有两个版 ...
- MobaXterm替换cmder
Windows上命令行工具cmder确实很好用,其扩展功能呢,比系统自带强大几倍.后来在使用MobaXterm,官网https://mobaxterm.mobatek.net/免费版本功能足够强大,支 ...
- P3768 简单的数学题 杜教筛+推式子
\(\color{#0066ff}{ 题目描述 }\) 由于出题人懒得写背景了,题目还是简单一点好. 输入一个整数n和一个整数p,你需要求出(\(\sum_{i=1}^n\sum_{j=1}^n ij ...
- luogu2658 GCD(莫比乌斯反演/欧拉函数)
link 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 1<=N<=10^7 (1)莫比乌斯反演法 发现就是YY的GCD,左转YY的GCD ...
- Nginx01---简单使用
基于腾讯云--ubuntu系统 1.安装nginx sudo apt-get install nginx 2.启动,停止nginx nginx -c /usr/local/nginx/conf/ngi ...
- C#校验手机端或客户端
以下代码用来检查,客户端是手机端还是PC端 string strUserAgent = Request.UserAgent.ToString().ToLower(); bool isMobile = ...
- linux 底层 基础命令 路径信息
z基础命令: 打印 :echo "hello world“ 切换目录 cd / 显示当前路径 pwd 显示 目录下所有文件 ls 显示所有文件包括隐藏文件 ls ...
- day_09 函数及参数
1.定义:把功能封装起来,方便下次直接调用 2.语法:def 关键词开头,空格之后接函数名称和圆括号(). def 函数名(形参) 函数体 3.参数:圆括号用来接收参数.若传入多个参数,参数之间用逗号 ...
- AsyncLocal 与 ThreadLocal ThreadStatic特性简介
AsyncLocal 与 ThreadLocal [.NET深呼吸]基于异步上下文的本地变量(AsyncLocal) https://www.cnblogs.com/tcjiaan/p/5007737 ...
- Reactive Extensions入门
https://www.cnblogs.com/yangecnu/archive/2012/11/03/Introducting_ReactiveExtensions.html 前面我写过7篇文章粗略 ...