解题思路:
1.绝对值函数abs()在头文件math.h里面

2.最小距离比较得来是关键

参考代码:

#include<stdio.h>
#include<math.h>//包含绝对值函数的头文件
int main()
{
    int f[1000],g[1000];//两个数组
    int m,n,d=0;//分别为用户定义的数组的长度m,n,其中d为最小距离
    int i,j,t;
    scanf("%d %d",&m,&n);//用户输入两个数组的长度
    for(i=0;i<m;++i)
        scanf("%d",&f[i]);//分别输入两个数组的元素
    for(i=0;i<n;++i)
        scanf("%d",&g[i]);
    for(i=0;i<m;i++)//两个数组元素间的差值不会大于其中元素的最大值,下面两次循环的目的就是找到最大值
    {
        if(f[i]>d)
        d=f[i];
    }
    for(j=0;j<n;j++)
    {
        if(g[j]>d)
        d=g[j];
    }
    for(i=0;i<m;++i)//循环比较得出最小距离
    {
        for(j=0;j<n;++j)
        {
            t=abs(f[i]-g[j]); //t临时存储距离绝对值的最小值,其中abs()为绝对值函数
            if(t<d)//如果得出的t比前面得出的d小,就将其给d
              d=t; 
        }
    }
    printf("%d\n",d);//输出
    return 0;
}

看看大家还有什么不懂的,请在下方评论区留言

点赞(8)
 

0.0分

11 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 13 条评论

小屁孩 1年前 回复TA
#include <stdio.h>
#include<math.h>
int main()
{
    int m,n,a[10],b[10];
    scanf("%d""%d",&m,&n);
    int i,j;
    int min = 1000;
    for(i=0;i<m;i++){
        scanf("%d",&a[i]);
    }
    for(i=0;i<n;i++){
        scanf("%d",&b[i]);
    }
    for(i=0;i<n;i++){
        for(j=0;j<m;j++){
            if(min>abs(a[j]-b[i])){
                min = abs(a[j]-b[i]);
            }
        }
    }
    printf("%d",min);
    return 0;
}
请问为什么运行错误啊???
追梦人 2年前 回复TA
#include<stdio.h>
int main(void)
{
	int m,n;
	scanf("%d%d",&m,&n);
	int f[m],g[n];
	for(int i=0;i<m;i++)
	scanf("%d",&f[i]);
	for(int i=0;i<n;i++)
	scanf("%d",&g[i]);
	int a,b;a=f[0]-g[0];
	if(a<0)a=-a;
	for(int i=0;i<m;i++)
	{
		for(int j=0;j<n;j++)
		{
			b=f[i]-g[j];
			if(b<0)
			{
				b=-b;
			}
			if(b<a)
			{
				a=b;
			}
		}
	}
	if(a>0)
	printf("%d",a);
	else
	printf("%d",-a);
}
uq_23481858568 3年前 回复TA
@LinYuan i++也是可以的
RioTian 5年前 回复TA
@RioTian 但牺牲了运行效率的感觉
RioTian 5年前 回复TA
#include<stdio.h>
#include<math.h>

int main()
{
	int f[1000];
	int g[1000];
	int n, m;
	scanf("%d %d", &n, &m);
	int i, j, d = 0;
	if ((m >= 1 && m <= 1000) && (n >= 1 && n <= 1000))
	{
		for (i = 0; i < n; i++)
		{
			scanf("%d", &f[i]);
			if (d < f[i])
				d = f[i];
		}
		for (i = 0; i < m; i++)
		{
			scanf("%d", &g[i]);
			if (d < g[i])
				d = g[i];
		}
	}
	int t;
	for (i = 0; i <n; i++)
	{
		for (j = 0; j < m; j++)
		{
			t = abs(f[i] - g[j]);
			if (t < d)
				d = t;
		}
	}
	printf("%d", d);
}

这样写稍微好点
kgin 5年前 回复TA
#include <stdio.h>
#include <math.h>
int main (void)
{
    int m, n, i, j, t, min;
	int f[1001], g[1001];
	scanf ("%d %d", &m, &n);
    for (i=0; i<m; i++)
      scanf ("%d", &f[i]);
    for (j=0; j<n; j++)
      scanf ("%d", &g[j]);
    min=abs(f[0]-g[0]);
    for (i=0; i<m; i++){
       for (j=0; j<n; j++){
       	   if(min>abs(f[i]-g[j]))
       	      min=abs(f[i]-g[j]);
	   }
	}
	printf ("%d\n", min);
	return 0;
}
LinYuan 5年前 回复TA
为什么要++i  能解释一下吗
saitama 6年前 回复TA
for(i=0;i<m;i++)//两个数组元素间的差值不会大于其中元素的最大值,下面两次循环的目的就是找到最大值
    {
        if(f[i]>d)
        d=f[i];
    }
我觉得这一步不是必要的吧。
直接找一个变量来把abs(f[0]-g[0])de 值存起来,之后比较求最小的就行吧
Mister-小方 7年前 回复TA
@Langzihao. 哈哈哈哈,你开心我就开心
Langzihao. 7年前 回复TA
@Langzihao. 学习小方的代码风格,好整齐,开心