题目:给你N个正整数,求两两之差的绝对值之和。 比如有4个数分别为 3,2,6,5,
则答案为 |3-2| + |3-6| + |3-5| + |2-6| + |2-5| + |6-5| =14
我试了三种方法,代码片段如下
一: for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
zhong=a[i]-a[j];
if(zhong<0)
{
sum=sum-zhong;
}
else sum=sum+zhong;
}
}
二:scanf("%d",&a[0]);
for(i=1;i<n;i++)
{
scanf("%d",&a[i]);
for(j=0;j<i;j++)
{
zhong=a[j]-a[i];
if(zhong<0) sum=sum-zhong;
else sum=sum+zhong;
}
}
三:for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
sort(a,a+n);
sum=0;
for(i=0;i<n;i++)
{
sum=sum-a[i]*(n-(i+1)-i);
}
可以看出,第一种方法最复杂,第三种方法最简单,前面两种都有两个for循环,时间复杂度为O(n²),
而第三种的时间复杂度为O(n),所以在此题中第三种解法最佳。
本文探讨了计算一组正整数两两之差绝对值之和的问题,并提供了三种不同的算法实现方式。通过对比分析,指出第三种方法利用排序简化计算过程,其时间复杂度优于前两种方法。

552

被折叠的 条评论
为什么被折叠?



