问题 1164: 【数组的距离】
时间限制: 1Sec 内存限制: 128MB 提交: 517 解决: 261
题目描述
已知元素从小到大排列的两个数组x[]和y[],请写出一个程序算出两个数组彼此之间差的绝对值中最小的一个,这叫做数组的距离
输入
第一行为两个整数m, n(1≤m, n≤1000),分别代表数组f[], g[]的长度。
第二行有m个元素,为数组f[]。
第三行有n个元素,为数组g[]。
输出
数组的最短距离
样例输入
<span style="color:#"><span style="color:#">5 5 1 2 3 4 5 6 7 8 9 10 </span></span>
讯享网
样例输出
讯享网<span style="color:#"><span style="color:#">1</span></span>
提示
这类题都为多组测试数据,ACM入门见蓝桥杯ACM训练系统基本输入输出教程
关于判题结果,有问题可以参考训练场题库中判题结果的详细解释
平时可多参加比赛C语言网有奖月赛
原题链接
import java.util.Scanner; public class 数组的距离 { public static void main(String[] args) { Scanner in = new Scanner(System.in); int n = in.nextInt(); int m = in.nextInt(); int[] a = new int[n]; int[] b = new int[m]; for(int i=0;i<n;i++) a[i] = in.nextInt(); for(int i=0;i<m;i++) b[i] = in.nextInt(); int ans = Integer.MAX_VALUE; for(int i=0;i<n;i++) for(int j=0;j<m;j++) ans=Math.min(ans, Math.abs(a[i]-b[j])); System.out.println(ans); } }
解题思路:
1.输入第一个数组X[];
2.第二个数组Y[],不用数组,用变量Y存每一个元素值;
3.第一个数组输入完成后,输入第二个数组;
4.第二个数组Y的元素,每输入一个,与数组X[],的每一个元素求一个距离,保留最小距离;
| 1 2 3 4 5 6 7 8 |
|
5.分析题目,最小距离为0,所以若某一个Y中元素与X[],中元素距离等于0时,之后的Y就都不用求距离了;
| 1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
也可以这样写:
| 1 2 3 4 5 6 7 8 9 10 11 12 |
|
注意事项
输入的可能有负数,要求距离,不是求差;
参考代码:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
|
当然还有更快的方法:
思路:
把两个数组合并排序;
1 3 2 6 5
4 8 7 9 0
得到 :0 1 2 3 4 5 6 7 8 9
把相邻的,且为来自两个不同数组的元素,相减求出距离,再选出最小距离;
关键就是怎么区分哪两个数来自不同数组;
代码没写给个思路;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/57884.html