∅π 2021-11-07 11:25 采纳率: 33.3%
浏览 642
已结题

找数字 给定一串递增数列,找到其中两个不同的数字 a[i] 和 a[j],使得a[i] + a[j] = k,并输出较小的那个数。

给定一串递增数列,找到其中两个不同的数字 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
    关注
    1. #include <stdio.h>
    2. int main()
    3. {
    4. int a[1000];
    5. int n,k,i,j,t,f=0;
    6. scanf("%d%d",&n,&k);
    7. for(i=0;i<n;i++)
    8. scanf("%d",&a[i]);
    9. for(i=0;i<n;i++)
    10. {
    11. if(f==1)
    12. break;
    13. if(a[i] >= k)
    14. break;
    15. for(j=i+1;j<n;j++)
    16. {
    17. t = a[i] + a[j];
    18. if(t==k)
    19. {
    20. printf("%d",a[i]);
    21. f = 1;
    22. break;
    23. }
    24. if(t>k)
    25. break;
    26. }
    27. }
    28. if(f==0)
    29. printf("-1");
    30. return 0;
    31. }

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    m0_71095455 2022-09-19 11:44

    怎么输出的是-1

    回复
    乱悄悄 回复 m0_71095455 2022-09-24 08:31

    我也想问

    回复
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 11月20日
  • 已采纳回答 11月13日
  • 创建了问题 11月7日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部