C语言一菜鸟级


私信TA

用户名:LHL

访问量:66231

签 名:

AC总是意料之外 ^_^

等  级
排  名 53
经  验 11536
参赛次数 5
文章发表 56
年  龄 24
在职情况 在职
学  校 四川工商学院
专  业 通信工程

  自我简介:

C语言 蓝桥杯 ACM 新人 欢迎大佬 前来指导 交流 本人 博客https://fivecc.blog.csdn.net/

解题思路:将先第一数组储存起来 输入第二数组时 每输入一位输入 去与第一数组元素遍历找到 当前最优数组距离(优化:因为数组元素为单调递增所以距离的结果也为单调 如果当前处理与第一数组的元素大于前面处理过的则单调性破坏break跳出不用处理后面 后面的距离必然越来越大)
注意事项:

参考代码:

#include <stdio.h>
#include <stdlib.h>
long int abss(long int s)//绝对值
{
    if(s<0)return -s;
    else return s;
}
int main()
{
    long int m,n,i,j,s,jl,ans,flag=0; 
    long int f[1001];
    scanf("%ld%ld",&m,&n);
    for(i=0;i<m;i++)
   scanf("%ld",&f[i]);
    for(i=0;i<n;i++)
    { scanf("%ld",&s);
        if(!flag)                     
        {   for(j=0;j<m;j++)
             if(abss(s-f[j])<ans||j==0)ans=abss(s-f[j]);//求距离所以用绝对值
             else break;  //优化(单调性被破坏,上一个点位 极值点)
             if(ans<jl||i==0)jl=ans;
             if(jl==0||s>f[m-1])flag=1;  //如果第二个数组的第一个(或任意)元素
                                        //大于第一个数组的最后一个元素 
        }                               //那么距离就是只能jl=s-f[m-1] flag标记 后面不用处理
        
    }
    printf("%ld\n",jl);
    return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »