ACM练习 两数组的距离
2013-05-25 13:02
288 查看
Description
已知元素从小到大排列的两个数组x[]和y[],请写出一个程序算出两个数组彼此之间差的绝对值中最小的一个,这叫做数组的距离。
Input
第一行为两个整数m, n(1≤m, n≤1000),分别代表数组f[], g[]的长度。 第二行有m个元素,为数组f[]。 第三行有n个元素,为数组g[]。
Output
数组的最短距离
Sample Input
5 5
1 2 3 4 5
6 7 8 9 10
Sample Output
1
这个题一开始用的大数组方法定义,但经常出现runtime error 后来老师启发用动态数组 可以通过
代码如下
已知元素从小到大排列的两个数组x[]和y[],请写出一个程序算出两个数组彼此之间差的绝对值中最小的一个,这叫做数组的距离。
Input
第一行为两个整数m, n(1≤m, n≤1000),分别代表数组f[], g[]的长度。 第二行有m个元素,为数组f[]。 第三行有n个元素,为数组g[]。
Output
数组的最短距离
Sample Input
5 5
1 2 3 4 5
6 7 8 9 10
Sample Output
1
这个题一开始用的大数组方法定义,但经常出现runtime error 后来老师启发用动态数组 可以通过
#include<iostream> #include<cmath> using namespace std; int main() { int a,b,i,j; cin>>a>>b; int * f = new int [a]; int * g = new int [b]; int p = 0; while(p < a) cin>>f[p++]; p = 0; while(p < b) cin>>g[p++]; int min = fabs(f[0] - g[0]); //给min设初值 if(min != 0) { for(i = 0;i < a;i++) //遍历求最小值min for(j = 0;j < b;j++) { int temp = fabs(f[i] - g[j]); min = temp < min ? temp : min; } } cout<<min; return 0; }
代码如下
相关文章推荐
- 两数组最短距离 acm
- Java练习--数组最大距离
- openjudge 计算概论-数组练习-距离排序
- 两数组最短距离 acm
- 山东理工大学ACM平台题答案关于C语言 1228 两数组最短距离
- 第十八周自由练习项目——acm 对象数组求最大值
- acm--两数组最短距离
- ACM练习—素数距离问题
- C语言编程(练习2:数组和指针)
- ACM 题目1167:数组排序
- java基础学习记录之数组最值的学习与练习一
- 面向对象程序设计上机练习八(对象数组)
- 背包算法练习--求小于某数字的数组最大和:
- Gym - 101194F Mr. Panda and Fantastic Beasts [2016-2017 ACM-ICPC CHINA-Final] [后缀数组]
- 练习用数组判断某天是该年的第几天
- acm-统计字符数组中各种类型字符的个数
- javaseday34补充2(数组 函数 匿名函数 数组排序 封装的力量 二分查找复习 数组小练习 查找 反转 )
- ACM第一次练习—1016
- 第05章 数组 11 练习9
- 蓝桥杯练习-操作格子【树状数组】