ACDream - Sum
先上题目:
Problem Description
给出N,a[1]... a[N],还有M,b[1]... b[M]
long long ans = 0;
for(int i = 1; i <= N; i ++)
for(int j = 1; j <= M; j ++)
ans += abs(a[i] - b[j]) * (i - j);
Input
多组数据,每组数据
第一行N,M(1 <= N,M <= 50000)
第二行N个数字,a[1].. a[N]
第三行M个数字,b[1]..b[M]
(1 <= a[i],b[i] <= 10000)
Output
Sample Input
4 4
1 2 3 4
5 6 7 8
Sample Output
-40
Hint
/*
* this code is made by sineatos
* Problem: 1174
* Verdict: Accepted
* Submission Date: 2014-08-01 12:08:56
* Time: 2488MS
* Memory: 3240KB
*/
#include <cstdio>
#include <cstring>
#include <utility>
#include <algorithm>
#define MAX 50002
#define ll long long
using namespace std; typedef pair<int,int> pii; pii a[MAX],b[MAX];
int n,m;
ll sumb[MAX],sumbj[MAX],sumj[MAX];
int loc[MAX]; inline ll Sum(int i,int r,int l){
ll sum=;
sum=(ll)a[i].first*a[i].second*(r+-l) - (ll)a[i].first*(sumj[r]-sumj[l-]) -(ll)a[i].second*(sumb[r]-sumb[l-]) + (sumbj[r]-sumbj[l-]);
return sum;
} int main()
{
ll sum;
//freopen("data.txt","r",stdin);
while(scanf("%d %d",&n,&m)!=EOF){
for(int i=;i<=n;i++){
scanf("%d",&a[i].first);
a[i].second=i;
}
for(int i=;i<=m;i++){
scanf("%d",&b[i].first);
b[i].second=i;
}
sort(a+,a+n+);
sort(b+,b+m+);
sumb[]=sumbj[]=sumj[]=;
int k=;
for(int i=;i<=n;i++){
while(k<=m && a[i].first>=b[k].first) k++;
loc[i]=k;
}
for(int i=;i<=m;i++){
sumb[i]=sumb[i-]+b[i].first;
sumbj[i]=sumbj[i-]+(ll)b[i].first*b[i].second;
sumj[i]=sumj[i-]+b[i].second;
}
sum=;
for(int i=;i<=n;i++){
int mid=loc[i];
ll p1=Sum(i,m,mid);
ll p2=Sum(i,mid-,);
sum+=p2-p1;
}
printf("%lld\n",sum);
}
return ;
}
/*Sum*/
ACDream - Sum的更多相关文章
- acdream Divide Sum
Divide Sum Time Limit: 2000/1000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) SubmitSta ...
- acdream 1148 GCD SUM 莫比乌斯反演 ansx,ansy
GCD SUM Time Limit: 8000/4000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) SubmitStatis ...
- acdream 1154 Lowbit Sum
先贴代码,以后再写题解... 首先,直接枚举肯定是会超时的,毕竟n就有10^9那么多... 对于每个数,我们先把它转化为二进制:例:21-->10101: 对于00001~10101,可以分为几 ...
- ACdream: Sum
Sum Time Limit: 2000/1000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) SubmitStatisticN ...
- acdream 1431 Sum vs Product
Sum vs Product Time Limit: 4000/2000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) Submi ...
- ACdream 1431——Sum vs Product——————【dfs+剪枝】
Sum vs Product Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) S ...
- ACDream - Power Sum
先上题目: Power Sum Time Limit: 20000/10000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) S ...
- ACDream - Lowbit Sum
先上题目: C - Lowbit Sum Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others ...
- ACdream 1154 Lowbit Sum (数位DP)
Lowbit Sum Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) SubmitSt ...
随机推荐
- 枚举类enum的values()方法
value()方法可以将枚举类转变为一个枚举类型的数组,因为枚举中没有下标,我们没有办法通过下标来快速找到需要的枚举类,这时候,转变为数组之后,我们就可以通过数组的下标,来找到我们需要的枚举类.接下来 ...
- 返回Json和XML两种格式
由于项目需要,同一接口支持根据参数不同返回XML和Json两种格式的数据,在网上看了很多大多是加后缀的方式来实现返回不同格式数据的,后来看了一篇http://www.importnew.com/276 ...
- JS 正则查找与替换
JS正则查找与替换 一.前提/背景 今天遇到个问题,需要替换字符串中部分字符,这些字符相对整个字符串而言,与其他子字符串类似,无法单独提出:重要的是,该字符串是动态的生成的,就像我们日常看到的网页Ur ...
- phonegap在eclipse上的安装
1.首先安装好eclipse 2.下载安装好sdk 3.下载安装好adt 4.在这个地方下载好phonegap的包,https://codeload.github.com/phonegap/phone ...
- ACM_招新笔试题系列——买包子
招新笔试题系列——买包子 Time Limit: 2000/1000ms (Java/Others) Problem Description: 小华刚到大学,一天早上她替她室友买早餐,一共要N个包子. ...
- servlet范围:数据共享
数据共享: 请求转发:request.getDispatcher("相对路径").forward(request,response) 重定向:response.sendRedire ...
- 使用A*寻路小记
前几天做另一个DEMO 要用实现自动寻路功能,看到普遍都是A* 学习了下 我的主循环代码: isFindEndPoint = false; //主循环 do { CreateOutSkirtsNode ...
- 用nginx实现分布式限流
1.前言 一般对外暴露的系统,在促销或者黑客攻击时会涌来大量的请求,为了保护系统不被瞬间到来的高并发流量给打垮, 就需要限流 . 本文主要阐述如何用nginx 来实现限流. 听说 Hystrix 也可 ...
- Spring学习_day03_事务
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! Spring_day03 一.事务 1.1 事务 事务 ...
- Centos6.6 安装nfs网络文件系统
一.介绍 nfs网络文件系统的,大部分用在内网文件共享,比如,对集群上传文件做共享,经常用在图片部分,当然数据量大了还是要做分离,做为专门的接口比较好,介绍一下基本安装环境: 1)Cnetos6.6 ...