D. Professor GukiZ and Two Arrays

题目连接:

http://www.codeforces.com/contest/620/problem/D

Description

Professor GukiZ has two arrays of integers, a and b. Professor wants to make the sum of the elements in the array a sa as close as possible to the sum of the elements in the array b sb. So he wants to minimize the value v = |sa - sb|.

In one operation professor can swap some element from the array a and some element from the array b. For example if the array a is [5, 1, 3, 2, 4] and the array b is [3, 3, 2] professor can swap the element 5 from the array a and the element 2 from the array b and get the new array a [2, 1, 3, 2, 4] and the new array b [3, 3, 5].

Professor doesn't want to make more than two swaps. Find the minimal value v and some sequence of no more than two swaps that will lead to the such value v. Professor makes swaps one by one, each new swap he makes with the new arrays a and b.

Input

The first line contains integer n (1 ≤ n ≤ 2000) — the number of elements in the array a.

The second line contains n integers ai ( - 109 ≤ ai ≤ 109) — the elements of the array a.

The third line contains integer m (1 ≤ m ≤ 2000) — the number of elements in the array b.

The fourth line contains m integers bj ( - 109 ≤ bj ≤ 109) — the elements of the array b.

Output

In the first line print the minimal value v = |sa - sb| that can be got with no more than two swaps.

The second line should contain the number of swaps k (0 ≤ k ≤ 2).

Each of the next k lines should contain two integers xp, yp (1 ≤ xp ≤ n, 1 ≤ yp ≤ m) — the index of the element in the array a and the index of the element in the array b in the p-th swap.

If there are several optimal solutions print any of them. Print the swaps in order the professor did them.

Sample Input

5

5 4 3 2 1

4

1 1 1 1

Sample Output

1

2

1 1

4 2

Hint

题意

给你两个数组,a数组和b数组

你可以用a数组中的一个数,交换到b数组去

然后使得abs(suma-sumb)最小

你最多交换两次

让你输出方案

题解:

交换0次和交换一次,显然可以直接暴力出来

现在考虑交换两次的情况,交换两次之后,答案为s-2*a[i]-2*a[j]+2*b[i]-2*b[j](s为原来未交换的时候,两个数组的差值

我们把所有的(a[i],a[j])都存起来,为了使两数组之差最小,显然2*(b[i]+b[j])应该找到大于等于(2*(a[i]+a[j])-s)的第一个数

然后这个东西直接二分就好了

然后这道题就结束了。。

代码

#include<bits/stdc++.h>
using namespace std; const int maxn = 2050;
int a[maxn];
int b[maxn];
pair<int,int> ans1;
pair<int,int> ans21,ans22;
pair<long long ,pair<int,int> >two[maxn*maxn+5];
int tot = 0;
int main()
{
long long s = 0;
int n;scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]),s+=a[i];
int m;scanf("%d",&m);
for(int i=1;i<=m;i++)
scanf("%d",&b[i]),s-=b[i];
long long s2 = 1e18;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
long long cur = abs(s + 2*b[j] - 2*a[i]);
if(cur<s2)
{
s2 = cur;
ans1=make_pair(i,j);
}
}
}
for(int i=1;i<=m;i++)
for(int j=i+1;j<=m;j++)
two[++tot]=make_pair(2ll*b[i]+2ll*b[j],make_pair(i,j));
sort(two+1,two+1+tot);
long long s3 = 1e18;
for(int i=1;i<=n;i++)
{
for(int j=i+1;j<=n;j++)
{
long long tmp = 2ll*a[i]+2ll*a[j]-s;
int p = lower_bound(two+1,two+1+tot,make_pair(tmp,make_pair(0,0)))-two;
for(int t=max(1,p-2);t<=min(tot,p+2);t++)
{
long long cur = abs(s+two[t].first-2ll*a[i]-2ll*a[j]);
if(cur<s3)
{
s3 = cur;
ans21 = make_pair(i,two[t].second.first);
ans22 = make_pair(j,two[t].second.second);
}
}
}
}
long long ans = min(min(abs(s),abs(s2)),abs(s3));
printf("%lld\n",ans);
if(ans==s)
printf("0\n");
else if(abs(s2)==ans)
{
printf("1\n");
printf("%d %d\n",ans1.first,ans1.second);
}
else
{
printf("2\n");
printf("%d %d\n%d %d\n",ans21.first,ans21.second,ans22.first,ans22.second);
}
}

Educational Codeforces Round 6 D. Professor GukiZ and Two Arrays 二分的更多相关文章

  1. Educational Codeforces Round 6 D. Professor GukiZ and Two Arrays

    Professor GukiZ and Two Arrays 题意:两个长度在2000的-1e9~1e9的两个序列a,b(无序);要你最多两次交换元素,使得交换元素后两序列和的差值的绝对值最小:输出这 ...

  2. Educational Codeforces Round 6 A. Professor GukiZ's Robot 水

    A. Professor GukiZ's Robot   Professor GukiZ makes a new robot. The robot are in the point with coor ...

  3. Codeforces Educational Codeforces Round 3 D. Gadgets for dollars and pounds 二分,贪心

    D. Gadgets for dollars and pounds 题目连接: http://www.codeforces.com/contest/609/problem/C Description ...

  4. Educational Codeforces Round 64 (Rated for Div. 2) (线段树二分)

    题目:http://codeforces.com/contest/1156/problem/E 题意:给你1-n  n个数,然后求有多少个区间[l,r] 满足    a[l]+a[r]=max([l, ...

  5. Educational Codeforces Round 3 D. Gadgets for dollars and pounds 二分+前缀

    D. Gadgets for dollars and pounds time limit per test 2 seconds memory limit per test 256 megabytes ...

  6. Educational Codeforces Round 61 (Rated for Div. 2)D(二分,模拟,思维)

    #include<bits/stdc++.h>using namespace std;typedef long long ll;int n,k;ll a[200007],b[200007] ...

  7. Educational Codeforces Round 21 D - Array Division (前缀和+二分)

    传送门 题意 将n个数划分为两块,最多改变一个数的位置, 问能否使两块和相等 分析 因为我们最多只能移动一个数x,那么要么将该数往前移动,要么往后移动,一开始处理不需要移动的情况 那么遍历sum[i] ...

  8. Educational Codeforces Round 80 (Rated for Div. 2)D(二分答案,状压检验)

    这题1<<M为255,可以logN二分答案后,N*M扫一遍表把N行数据转化为一个小于等于255的数字,再255^2检验答案(比扫一遍表复杂度低),复杂度约为N*M*logN #define ...

  9. Educational Codeforces Round 77 (Rated for Div. 2)D(二分+贪心)

    这题二分下界是0,所以二分写法和以往略有不同,注意考虑所有区间,并且不要死循环... #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> ...

随机推荐

  1. Python脚本 - 常用单位转换

    测试系统为:Centos 6.7 Python版本为: 3.6.4 脚本功能:常用单位的转换,这里用内存来模拟 import pstuil def bytes2human(n): symbols = ...

  2. Python学习笔记 - day8 - 异常

    异常 在程序运行过程中,总会遇到各种各样的错误.有的错误是程序编写有问题造成的,比如本来应该输出整数结果输出了字符串,有的错误是用户输入造成的,比如让用户输入email地址,结果得到一个空字符串,这种 ...

  3. 【Python学习】程序运行完发送邮件提醒

    有时候我们运行一个需要跑很长时间的程序,不管是在云主机还是本地主机上运行,我们都不可能一直守在电脑面前等.所以想到使用邮件来通知提醒. 示例代码如下 # -*- coding: utf-8 -*- # ...

  4. 【Python学习笔记】使用Python进行主成分分析

    使用sklearn库中的PCA类进行主成分分析. 导入要用到的库,还没有的直接pip安装就好了. from sklearn.decomposition import PCA import numpy ...

  5. selenium===requestium模块介绍

    有时,你可能会在网上实现一些自动化操作.比如抓取网站,进行应用测试,或在网上填表,但又不想使用API,这时自动化就变得很必要.Python提供了非常优秀的Requests库可以辅助进行这些操作.可惜, ...

  6. python实战===用python调用jar包(原创)

    一个困扰我很久的问题,今天终于解决了.用python调用jar包 很简单,但是网上的人就是乱转载.自己试都不试就转载,让我走了很多弯路 背景:python3.6 32位   + jre 32位  +  ...

  7. Oracle11g常用的命令

    cmd H: cd H:\oracle\product\\Db_1\BIN exp jz/jz file=C:/QS-BF20131017.dmp (备份) imp jz/jz file=C:/BF2 ...

  8. python读写xml文件

    python读取xml文件 xml文件是具有树状结构的,如果想要访问某个叶子结点,必须逐层获取其父结点,要读取某个叶子结点内容用text成员 使用前先加载xml工具包 try: import xml. ...

  9. 解决Tomcat因Redis加载慢而启动失败的问题

    StartTomcat.py import subprocess as t import time, os, requests, sys WEB_IP = '127.0.0.1:8080' # WEB ...

  10. 详解WordPress中简码格式标签编写的基本方法

    WordPress 简码是一种类似于论坛标签的东西,格式类似于把尖括号换成中括号的 Html 标签.简码很多人叫做短代码,但官方的翻译应该是简码,在这里纠正一下. 简码的开发的逻辑比较简单,主要就是添 ...