给定一串递增数列,找到其中两个不同的数字 a[i] 和 a[j],使得a[i] + a[j] = k,并输出较小的那个数。
如果有组a[i] 和 a[j] 满足条件,则输出其中数值最小的数,如果没有找到,输出-1。
输入
输入为一串递增数组 a 和一个正整数 k,其中
1 <= a.length <= 10^5
1 <= a[i] <= 10^6
1 <= k <= 10^6
输出
输出为一个整数,表示在递增数组 a 中找到的两个相加和等于 k中较小的那个数,如果找到多组这样的数,输出值最小的那个数。
2条回答 默认 最新
- CSDN专家-link 2021-11-07 11:32关注
- #include <stdio.h>
- int main()
- {
- int a[1000];
- int n,k,i,j,t,f=0;
- scanf("%d%d",&n,&k);
- for(i=0;i<n;i++)
- scanf("%d",&a[i]);
- for(i=0;i<n;i++)
- {
- if(f==1)
- break;
- if(a[i] >= k)
- break;
- for(j=i+1;j<n;j++)
- {
- t = a[i] + a[j];
- if(t==k)
- {
- printf("%d",a[i]);
- f = 1;
- break;
- }
- if(t>k)
- break;
- }
- }
- if(f==0)
- printf("-1");
- return 0;
- }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 5无用 1