首页 > 其他 > 详细

noip模拟赛 whzzt-Confidence

时间:2017-10-28 18:23:48      阅读:205      评论:0      收藏:0      [点我收藏+]

技术分享

分析:做着感觉像脑筋急转弯一样......因为空间的限制,存不下每一个数,所以用数学方法来解.

设t1=Σai - Σbi = aj - bj,t2=Σi*ai - Σi*bi = j*(aj - bj).j是a,b不相等的位置,t2/t1就是答案了.

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

int T, n;
long long a, b;

int main()
{
    scanf("%d", &T);
    while (T--)
    {
        a = b = 0;
        scanf("%d", &n);
        for (long long i = 1; i <= n; i++)
        {
            long long t;
            scanf("%lld", &t);
            a += t;
            b += i*t;
        }
        for (long long i = 1; i <= n; i++)
        {
            long long t;
            scanf("%lld", &t);
            a -= t;
            b -= i*t;
        }
        if (!a)
            printf("0\n");
        else
            printf("1 %lld\n", b / a);
    }

    return 0;
}

 

noip模拟赛 whzzt-Confidence

原文:http://www.cnblogs.com/zbtrs/p/7747371.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!