Mister-小方


私信TA

用户名:1104986125

访问量:237623

签 名:

如此英俊为哪般

等  级
排  名 3
经  验 35524
参赛次数 1
文章发表 68
年  龄 19
在职情况 学生
学  校 大连交通大学
专  业 车辆工程

  自我简介:

解题思路:
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;
}

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

 

0.0分

13 人评分

  评论区

#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;
}
请问为什么运行错误啊???
2023-03-20 22:44:28
#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);
}
2022-08-23 17:04:52
#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);
}

这样写稍微好点
2019-12-19 17:09:53
#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;
}
2019-12-11 08:08:23
为什么要++i  能解释一下吗
2019-09-02 21:35:53
for(i=0;i<m;i++)//两个数组元素间的差值不会大于其中元素的最大值,下面两次循环的目的就是找到最大值
    {
        if(f[i]>d)
        d=f[i];
    }
我觉得这一步不是必要的吧。
直接找一个变量来把abs(f[0]-g[0])de 值存起来,之后比较求最小的就行吧
2018-12-15 08:15:12
#include <stdio.h>
#include <math.h>

void input(int a[],int n);
int Distance(int a[],int n,int b[],int m);

int m,n;
int x[1000];
int y[1000];
 
int main()
{
	scanf("%d%d",&m,&n);
	input(x,m);
	input(y,n);
	printf("%d",Distance(x,m,y,n));
	return 0;
}

void input(int a[],int n){
	int i;
	for(i=0;i<n;i++){
		scanf("%d",&a[i]);
	}
}

int Distance(int a[],int n,int b[],int m){
	int i,j,len;
	int minlen=fabs(a[0]-b[m-1]);
	for(i=0;i<n;i++){
		for(j=m-1;j>=0;j--){
			len=fabs(a[i]-b[j]);
			if(len<minlen)	minlen=len;
			if(minlen==0)	break;
		}
		if(minlen==0)	break;
	}
	return minlen;
}
2017-08-21 11:34:29
数组中可以是负数吗
2017-07-18 14:08:04
  • «
  • 1
  • »