2990 - 【入门】和为给定数
Time Limit : 1 秒
Memory Limit : 128 MB
给出若干个整数,询问其中是否有一对不同位置上数的和等于给定的数。
Input
共三行: 第一行是整数 n (0 < n ≤ 100,000),表示有 n 个整数。
第二行是 n 个整数。整数的范围是在 0 到 10^8 之间。
第三行是一个整数 m(0≤m≤2^30 ),表示需要得到的和。
Output
若存在和为 m 的数对,输出两个整数,小的在前,大的在后,中间用单个空格隔开。
若有多个数对满足条件,选择数对中较小的数更小的。若找不到符合要求的数对,输出一行No。
Examples
Input
4 2 5 1 4 6
Output
1 5
Input
7 10 20 1 2 6 8 12 18
Output
6 12
Input
7 10 20 1 2 6 8 12 24
Output
No
Source
双指针