codevs 1213 解的个数(我去年打了个表 - -)
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- using namespace std;
- int T,x,y,ans,g,l1,r1,l2,r2;
- int init()
- {
- int x=;char s=getchar();bool f=;
- while(s<''||s>''){if(s=='-')f=;s=getchar();}
- while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
- if(f)return -x;return x;
- }
- void E_gcd(int a,int b)
- {
- if(b==)
- {
- x=;y=;g=a;
- }
- else
- {
- E_gcd(b,a%b);
- int tmp=x;
- x=y;
- y=tmp-a/b*y;
- }
- }
- int main()
- {
- int a,b,c,i,j;
- T=init();
- while(T--)
- {
- ans=;
- a=init();b=init();c=init();
- c=-c;
- l1=init();r1=init();l2=init();r2=init();
- if(a==&&b==)
- {
- if(c!=||l1>r1||l2>r1)
- {
- printf("0\n");
- continue;
- }
- long long an,li,ri;
- li=r1-l1+;ri=r2-l2+;
- an=li*ri;
- cout<<an<<endl;
- continue;
- }
- if(a==)
- {
- y=c/b;
- if(y<l2||y>r2||c%b!=)
- printf("0\n");
- else
- printf("1\n");
- continue;
- }
- if(b==)
- {
- x=c/a;
- if(x<l1||x>r1||c%a!=)
- printf("0\n");
- else
- printf("1\n");
- continue;
- }
- E_gcd(a,b);
- if(c%g!=)
- {
- printf("0\n");
- continue;
- }
- int s=c/g;
- x*=s;y*=s;
- int ai=a/g;
- int bi=b/g;
- if(x<l1)
- {
- while(x<l1)
- {
- x+=bi;y-=ai;
- }
- for(i=x;i<=r1;i+=bi,y-=ai)
- if(y>=l2&&y<=r2)
- ans++;
- }
- else if(x>r1)
- {
- while(x>r1)
- {
- x-=bi;y+=ai;
- }
- for(i=x;i>=l1;i-=bi,y+=ai)
- if(y>=l2&&y<=r2)
- ans++;
- }
- else
- {
- int yi=y;
- for(i=x;i<=r1;i+=bi,yi-=ai)
- if(yi>=l2&&yi<=r2)
- ans++;
- yi=y+ai;
- for(i=x-bi;i>=l1;i-=bi,yi+=ai)
- if(yi>=l2&&yi<=r2)
- ans++;
- }
- printf("%d\n",ans);
- }
- return ;
- }
codevs 1213 解的个数(我去年打了个表 - -)的更多相关文章
- 扩展gcd codevs 1213 解的个数
codevs 1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x,y满足如下面的条件: ax+by ...
- codevs 1213 解的个数
1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x,y满足如下面的条件: ax+by+c = ...
- Codevs 1213 解的个数(exgcd)
1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x,y满足如下面的条件: ax+by+c=0 p< ...
- 解的个数(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 . 输入 ...
- PE文件格式详解,第三讲,可选头文件格式,以及节表
PE文件格式详解,第三讲,可选头文件格式,以及节表 作者:IBinary出处:http://www.cnblogs.com/iBinary/版权所有,欢迎保留原文链接进行转载:) 一丶可选头结构以及作 ...
- HDU1573 线性同余方程(解的个数)
X问题 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
随机推荐
- 如何在Android Studio中使用Gradle发布项目至Jcenter仓库
简述 目前非常流行将开源库上传至Jcenter仓库中,使用起来非常方便且易于维护,特别是在Android Studio环境中,只需几步配置就可以轻松实现上传和发布. Library的转换和引用 博主的 ...
- php实现base64编码
工作需要,想弄一个加密的串,就想仿照base64的编码方式,写一个加密的方法,所以就有了下面这个用php实现的base64的代码 <?php /** * Base64 编码/解码 * @auth ...
- ios 排序汇总
ios 排序汇总 IOS几种简单有效的数组排序方法 //第一种,利用数组的sortedArrayUsingComparator调用 NSComparator ,obj1和obj2指的数组中的对象 N ...
- Ruby自学笔记(一)— 基本概况
之前一直想要多看看RESTful Service相关的东西,找到一本相关的书,但是里面的代码都是用Ruby写的,虽然知道编程语言都是类似的,但是看到一些陌生的语法,还是有些摸不着头脑,所以最近终于下定 ...
- BZOJ 1057 棋盘制作
Description 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑白相间的方阵,对应八八六十四卦,黑白对应阴 ...
- MATLAB中多行注释的三种方法
MATLAB中多行注释的三种方法 A. %{ 若干语句 %} B. 多行注释: 选中要注释的若干语句, 编辑器菜单Text->Comment, 或者快捷键Ctrl+R 取消注释: 选中要取消注释 ...
- Spring MVC控制器用@ResponseBody声明返回json数据报406的问题
本打算今天早点下班,结果下午测试调试程序发现一个问题纠结到晚上才解决,现在写一篇博客来总结下. 是这样的,本人在Spring mvc控制层用到了@ResponseBody标注,以便返回的数据为json ...
- DB2中时间格式化
values to_char(current timestamp - 7 hours,'hh24')||'点' values varchar(hour(current time + 5 hour))| ...
- c# 集合ArrayList;特殊集合Stack、Queue
一) ArrayList 1.foreach遍历数组中各个元素,执行内部语句 2. 3. 4. myarry.Clear();//将集合清空 bool b = myarry.Contains(3 ...
- Vi的几种退出方式
1.q 退出 2.w 保存,继续操作 3.wq 保存退出 4.q! 不保存,放弃修改 5.x 同wq相似,但又有区别 wq 强制性写入文件并退出.即使文件没有被修改也强制写入,并更新文件的修改时间 ...