CSDN挑战编程——《绝对值最小》

来源:互联网 发布:淘宝主视频制作软件 编辑:程序博客网 时间:2024/05/18 16:16

绝对值最小

题目详情:

给你一个数组A[n],请你计算出ans=min(|A[i]+A[j]|)(0<=i,j<n).

例如:A={1, 4, -3},

则:

|A[0] + A[0]| = |1 + 1| = 2.

|A[0] + A[1]| = |1 + 4| = 5.

|A[0] + A[2]| = |1 + (-3)| = 2.

|A[1] + A[1]| = |4 + 4| = 8.

|A[1] + A[2]| = |4 + (-3)| = 1.

|A[2] + A[2]| = |(-3) + (-3)| = 6.

所以ans=1.

输入描述:

有多组测数数据,每组数据有两行,第一行包含一个正整数n(0<n<=100000),第二行包含n个整数,分别表示A[0],A[1],A[2],....,A[n-1],(|A[i]|<2^30)。

输入以文件结束。

输出描述:

对于每组数据,输出相应的答案。



答题说明:

输入样例:

3

1 4 -3

1

2

3

-1 -2 -5

3

1 2 3

2

0 5

输出样例:

1

4

2

2

0


[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. /*
  2.     解题思路:
  3.         对数组进行快速排序(排序后可以减少枚举的次数),然后枚举求解
  4. */ 
  5. #include "stdio.h" 
  6. #include "stdlib.h" 
  7.  
  8. #define abs(x)  ((x)>0?(x):-1*(x)) 
  9. #define maxn 100000+10 
  10. int a[maxn],n; 
  11.  
  12. int cmp(constvoid* _a,constvoid* _b){ 
  13.     int *a=(int *)_a; 
  14.     int *b=(int *)_b; 
  15.     return (*a-*b); 
  16.  
  17. int main() 
  18.     int ans; 
  19.     while(scanf("%d",&n)&&n>0) 
  20.     { 
  21.         int flag=1; 
  22.         for(int i=0;i<n;i++){ 
  23.             scanf("%d",&a[i]); 
  24.             if(!a[i]){ 
  25.                 ans=0; flag=0; 
  26.             } 
  27.         } 
  28.          
  29.         if(flag){ 
  30.             qsort((void *)a, n, sizeof(int), cmp);  
  31.             ans=abs(a[0]*2);         
  32.             for(int i=0;i<n;i++){ 
  33.                 int min=abs(2*a[i]); 
  34.                 for(int j=i+1,tmp;j<n;j++){ 
  35.                     tmp=abs(a[i]+a[j]);      
  36.                     if(tmp<min){ 
  37.                         min=tmp; 
  38.                     }else//不存在比min更小的解,退出内循环 
  39.                         break
  40.                     } 
  41.                 } 
  42.                 if(min<ans) ans=min; 
  43.             }    
  44.         }            
  45.         printf("%d\n",ans);  
  46.     } 
  47.      
  48.     return 0; 
  49. }  
0 0