原题链接:数组的距离
解题思路:
1.输入第一个数组X[];
2.第二个数组Y[],不用数组,用变量Y存每一个元素值;
3.第一个数组输入完成后,输入第二个数组;
4.第二个数组Y的元素,每输入一个,与数组X[],的每一个元素求一个距离,保留最小距离;
for(int i=0;i<x;i++) //求最小距离 { if(Y>=X[i]&&(Y-X[i])<distance) //距离要用大的数减去小的数,且输入的数据有可能为负数 distance=Y-X[i]; else if(Y<X[i]&&(X[i]-Y)<distance) distance=X[i]-Y; }
5.分析题目,最小距离为0,所以若某一个Y中元素与X[],中元素距离等于0时,之后的Y就都不用求距离了;
if(distance!=0) //距离等于0,不用求之后输入Y的与X[]的距离了 { scanf("%d",&Y); for(int i=0;i<x;i++) //求最小距离 { if(Y>=X[i]&&(Y-X[i])<distance) //距离要用大的数减去小的数,因为输入的数据有可能为负数 distance=Y-X[i]; else if(Y<X[i]&&(X[i]-Y)<distance) distance=X[i]-Y; } } else scanf("%d",&Y);
也可以这样写:
scanf("%d",&Y); //把输入放外面 if(distance!=0) //距离等于0,不用求之后输入Y的与X[]的距离了 { for(int i=0;i<x;i++) //求最小距离 { if(Y>=X[i]&&(Y-X[i])<distance) //距离要用大的数减去小的数,因为输入的数据有可能为负数 distance=Y-X[i]; else if(Y<X[i]&&(X[i]-Y)<distance) distance=X[i]-Y; } }
注意事项
输入的可能有负数,要求距离,不是求差;
参考代码:
#include<stdio.h> #include<malloc.h> void function(int x,int y); /*===============================================*/ int main() { int x,y; while(scanf("%d%d",&x,&y)!=EOF) { function(x,y); } return 0; } /*===============================================*/ void function(int x,int y) { int *X; int Y; int distance=10000000; //用于记录最小距离 X=(int *)malloc(x*sizeof(int)); //为数组X[],开辟空间 for(int i=0;i<x;i++) scanf("%d",&X[i]); //输入X[],中元素 for(int j=0;j<y;j++) //输入Y,并求最小距离 { if(distance!=0) //距离等于0,不用求之后输入Y的与X[]的距离了 { scanf("%d",&Y); for(int i=0;i<x;i++) //求最小距离 { if(Y>=X[i]&&(Y-X[i])<distance) //距离要用大的数减去小的数,因为输入的数据有可能为负数 distance=Y-X[i]; else if(Y<X[i]&&(X[i]-Y)<distance) distance=X[i]-Y; } } else scanf("%d",&Y); } printf("%d\n",distance); }
当然还有更快的方法:
思路:
把两个数组合并排序;
1 3 2 6 5
4 8 7 9 0
得到 :0 1 2 3 4 5 6 7 8 9
把相邻的,且为来自两个不同数组的元素,相减求出距离,再选出最小距离;
关键就是怎么区分哪两个数来自不同数组;
代码没写给个思路;
别忘点赞哦-.-
0.0分
12 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复