问题描述
给两组数,各n个。
请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小。要求程序输出这个最小值。
例如两组数分别为:1 3 -5和-2 4 1
专注于为中小企业提供网站设计制作、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业光山免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近1000家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
那么对应乘积取和的最小值应为:
(-5) 4 + 3 (-2) + 1 * 1 = -25
输入格式
第一个行一个数T表示数据组数。后面每组数据,先读入一个n,接下来两行每行n个数,每个数的绝对值小于等于1000。
n<=8,T<=1000
输出格式
一个数表示答案。
样例输入
2
3
1 3 -5
-2 4 1
5
1 2 3 4 5
1 0 1 0 1
样例输出
-25 { }
6
两组数一组从大到小排列,一组从小到大排列。相乘即最小乘积。
#include
main()
{
int temp,T,i,j,l,m,w,n,e,sum;
scanf("%d",&T);
for(i=0;i
sum=0;
int num1[8],num2[8];
scanf("%d",&n);
for(l=0;l
scanf("%d",&num1[l]);
}for(e=0;e
当前标题:最小乘积(基本型)
文章链接:http://cxhlcq.com/article/gpdjdi.html