Fair warning -- long long

Problem

On our planet, Jamcode IX, three Great Events occurred. They happened 26000, 11000 and 6000 slarboseconds ago. In 4000 slarboseconds, the amount of time since all of those events will be multiples of 5000 slarboseconds, the largest possible amount... and the apocalypse will come.

Luckily for you, you live on Jamcode X! The apocalypse came on Jamcode IX less than a year ago. But Jamcode X has a worrying prophecy: "After the moment of reckoning, on the first optimum anniversary of the N Great Events, the apocalypse will come. 64 bits will not save you. You have been warned."

The people of Jamcode X are very concerned by this prophecy. All of the Great Events have already happened, and their times have been measured to the nearest slarbosecond; but nobody knows when their optimum anniversary will occur. After studying the diary of a scientist from Jamcode IX, scientists working on the problem have come up with a theory:

The moment of reckoning is now, the moment you solve this problem. At some time y ≥ 0slarboseconds from now, the number of slarboseconds since each of the Great Events will be divisible by some maximum number T. If you can find the smallest value of y that gives this largest possible T, that will give you the optimum anniversary when the apocalypse will come.

On Jamcode IX, for example, there were 3 Great Events and they happened 26000, 11000 and 6000 slarboseconds before the moment of reckoning. 4000 slarboseconds later, the amount of time since each event was a multiple of T=5000 slarboseconds, and the apocalypse came.

Your job is to compute the amount of time until the apocalypse comes. But remember the prophecy: even though the people of Jamcode X have been solving problems for two years, and 64-bit integers have always been enough, they might not always be enough now or in the future.

Input

The first line of the input gives the number of test cases, CC lines follow. Each starts with a single integer N, which is followed by a space and then N space-separated integersti, the number of slarboseconds since Great Event i occurred.

Output

For each test case, output one line containing "Case #x: y", where x is the case number (starting from 1) and y is the minimum number of slarboseconds until ti + y is a multiple of the largest possible integer factor T for all i.

Limits

1 ≤ C ≤ 100.
ti ≠ tj for some ij.

Small dataset

2 ≤ N ≤ 3.
1 ≤ ti ≤ 108.

Large dataset

2 ≤ N ≤ 1000.
1 ≤ ti ≤ 1050.

Sample


Input 
 
3
3 26000000 11000000 6000000
3 1 10 11
2 800000000000000000001 900000000000000000001

Output 
 
Case #1: 4000000
Case #2: 0
Case #3: 99999999999999999999

 
Solution:
// snapper.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <fstream>
#include <iostream>
#include <math.h> //pow(double, double)

using namespace std;
long long gcd(long long a, long long b)  //thats how you deal with over 64bits, Euclideanalgorithm(辗转相除法)
{
    if(b==0) return a;
    else(b, a%b);
}

int _tmain(int argc, _TCHAR* argv[])
{
    ifstream inf;
    inf.open("c:/in.txt",std::ifstream::in); // 右斜线
    ofstream outf;
    outf.open("c:/out.txt",std::ofstream::out);
    int T = 0;
    inf >> T;
    for (int i=0; i<T; ++i)
    {
        long long value[1000];
        int count = 0;
        inf >> count;
        for(int j=0; j<count; ++j)
        {
            inf >> value[j];
        }
        for(int k=count-1; k>=2; ++k)
        {
            for(int m=k; m>0; ++m)
            {
            value[m-1] = abs(value[m]-value[m-1]);
            }
        }
        int temp = 0;
        if(value[1] > value[2])
         temp = gcd(value[1],value[2]);
        else  temp = gcd(value[2],value[1]);
        outf << "case # " << i << temp;
    }
    return 0;
}

 

posted @ 2013-07-02 01:01  pgu2  阅读(210)  评论(0)    收藏  举报