两数组最小距离问题
来源:互联网 发布:linux date 输出格式 编辑:程序博客网 时间:2024/04/30 19:52
已知两个元素从小到大排列的数组x[]和y[],请写出一个程序算出两个数组元素彼此之间差的绝对值中最小的一个,这个叫做数组的距离。
这个问题不难,可以通过一个循环嵌套循环解决。但是既然说了两个数组元素都是从小到大排列,那么肯定有别的简单的办法。
如果x[i]>y[j],对于x[i]-y[j],所有排在y[j]之前的元素计算这个式子的值都会大于x[i]-y[j],因此,要想寻找到更小的距离,j++。
同理,如果x[i]<y[j],对于y[j]-x[i],所有排在x[i]之前的元素计算这个式子得出来的值都大于y[j]-x[i],因此,想寻找更小的值,i++。
明白了这个,代码就可以理解了。
/************************************************************************/ /* 两个数组最短距离问题 */ /* */ /************************************************************************/ #include <stdio.h> #include <limits.h> #define INFINITE INT_MAX /*int所能表示的最大值*/ #define min(x,y) ((x) < (y) ? (x) : (y)) /* x:第一个数组 m:数组x的长度 y:第二个数组 n:数组y的长度 */ int getMinDistNew(int x[], int m, int y[], int n) { int indexX,indexY; int minimum = INFINITE; indexX = 0; indexY = 0; while (indexX < m && indexY < n) { if (x[indexX] >= y[indexY]) { minimum = min(minimum,x[indexX] - y[indexY]); indexY++; } else { minimum = min(minimum,y[indexY] - x[indexX]); indexX++; } } return minimum; } int main() { int rst; int x[6] = {1,2,4,8,9,11}; int y[7] = {-5,-3,-1,0,3,4,9}; rst = getMinDistNew(x,6,y,7); printf("The minimum distance is %d\n",rst); return 0; }
- 两数组最小距离问题
- 字符串问题---数组中两个字符串的最小距离
- 最小距离问题
- 最小编辑距离问题
- 求三个数组的最小距离
- 数组中两个元素的最小距离
- 数组中两个字符串的最小距离
- 数组中两个元素最小的距离
- 数组中两个元素的最小距离
- 背包问题变种:将数组分成两部分使得两部分的和的差最小
- ACM练习 两数组的距离
- numpy计算两二维数组距离
- 最小编辑距离问题(Edition Distance)
- POJ3356:AGTC(最小编辑距离问题)
- 交换两数组元素使两数组和差值最小
- 最小距离
- 两数组包含问题
- 两数组包含问题
- jsp 与javascript传递参数
- MongoDB入门4——更新文档和修改器2
- Mac OS X下面相关快捷键
- 世界上最有名的话
- CCNA-动态路由之OSPF协议
- 两数组最小距离问题
- .net
- spring security
- CCNP---OSPF多区域+帧中继配置
- 【HTML】【CSS】表格设置了table-layout:fixed后第一行合并单元格其下单元格宽度设置不起作用的解决方法
- 迷宫问题:hdoj1242--BFS基本应用
- cron syntax
- Oracle存储过程实例2
- 我的2011,年终大盘点