CF1673D.Lost Arithmetic Progression
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Long ago, you thought of two finite arithmetic progressions A and B . Then you found out another sequence C containing all elements common to both A and B . It is not hard to see that C is also a finite arithmetic progression. After many years, you forgot what A was but remember B and C . You are, for some reason, determined to find this lost arithmetic progression. Before you begin this eternal search, you want to know how many different finite arithmetic progressions exist which can be your lost progression A .
Two arithmetic progressions are considered different if they differ in their first term, common difference or number of terms.
It may be possible that there are infinitely many such progressions, in which case you won't even try to look for them! Print −1 in all such cases.
Even if there are finite number of them, the answer might be very large. So, you are only interested to find the answer modulo 109+7 .
输入格式
The first line of input contains a single integer t ( 1≤t≤100 ) denoting the number of testcases.
The first line of each testcase contains three integers b , q and y ( −109≤b≤109 , 1≤q≤109 , 2≤y≤109 ) denoting the first term, common difference and number of terms of B respectively.
The second line of each testcase contains three integers c , r and z ( −109≤c≤109 , 1≤r≤109 , 2≤z≤109 ) denoting the first term, common difference and number of terms of C respectively.
输出格式
For each testcase, print a single line containing a single integer.
If there are infinitely many finite arithmetic progressions which could be your lost progression A , print −1 .
Otherwise, print the number of finite arithmetic progressions which could be your lost progression A modulo 109+7 . In particular, if there are no such finite arithmetic progressions, print 0 .
输入输出样例
输入#1
8 -3 1 7 -1 2 4 -9 3 11 0 6 3 2 5 5 7 5 4 2 2 11 10 5 3 0 2 9 2 4 3 -11 4 12 1 12 2 -27 4 7 -17 8 2 -8400 420 1000000000 0 4620 10
输出#1
0 10 -1 0 -1 21 0 273000
说明/提示
For the first testcase, B={−3,−2,−1,0,1,2,3} and C={−1,1,3,5} . There is no such arithmetic progression which can be equal to A because 5 is not present in B and for any A , 5 should not be present in C also.
For the second testcase, B={−9,−6,−3,0,3,6,9,12,15,18,21} and C={0,6,12} . There are 10 possible arithmetic progressions which can be A :
- {0,6,12}
- {0,2,4,6,8,10,12}
- {0,2,4,6,8,10,12,14}
- {0,2,4,6,8,10,12,14,16}
- {−2,0,2,4,6,8,10,12}
- {−2,0,2,4,6,8,10,12,14}
- {−2,0,2,4,6,8,10,12,14,16}
- {−4,−2,0,2,4,6,8,10,12}
- {−4,−2,0,2,4,6,8,10,12,14}
- {−4,−2,0,2,4,6,8,10,12,14,16}
For the third testcase, B={2,7,12,17,22} and C={7,12,17,22} . There are infinitely many arithmetic progressions which can be A like:
- {7,12,17,22}
- {7,12,17,22,27}
- {7,12,17,22,27,32}
- {7,12,17,22,27,32,37}
- {7,12,17,22,27,32,37,42}
- …