3.29 百度 笔试 三道编程题代码

(今天做了四场笔试,做到现在脑子都糊了)
第一题:
答案是取n和n-1,不知道为什么这样是对的,并感觉交了一发过了。
第二题
如果一个数出现了三次,或者有多个出现次数大于1的,第一个人一定输
最后就形成了 0,1,2,3,4...n-1 
到达这种情况必输,判断下奇偶就行
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=100050;
int a[maxn];
map<int,int>mp;
int main(){
    int n,t;
    scanf("%d",&t);
    while(t--){
        mp.clear();
        scanf("%d",&n);
        ll sum=0;
        int flag=0,num=0;
        for(int i=1;i<=n;i++){
            scanf("%d",&a[i]);
            if(mp[a[i]]==0) mp[a[i]]=1;
            else{
                mp[a[i]]++;
                if(mp[a[i]]==2) num++;
                if(mp[a[i]]>2){
                    flag=1;
                }
            }
            sum+=(ll)a[i];
            sum-=(i-1ll);
        }
        if(flag||num>1){
            printf("woman\n");
            continue;
        }
        if(sum%2ll) printf("man\n");
        else printf("woman\n");
    }
    return 0;
}


第三题:
二分答案x,然后如果两点的距离小于x,说明这两个点之间无法走通,用并查集维护一下, 最后上下边界都属于一个集合说明x大了,要取小一点,这样子二分答案。
k是6000,时间卡的有点紧,eps是关键,设打了wa,设小了T,交了好多发
#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i = (int)a;i<=(int)b;i++)
#define per(i,a,b) for(int i = (int)b;i>=(int)a;i--)
#define pb push_back
#define mp map_pair
#define all(x) (x).begin(),(x).end()
#define fi first
#define se second
#define SZ(x) ((int)(x).size())
const int maxn=100050;
typedef long long ll;
const double pi = acos(-1.0);//pi
const double eps=0.000003;
int dcmp(double x){
    if(fabs(x)<eps) return 0;
    if(x>eps) return 1;
    else return -1;
}
struct node{
    double x,y;
}a[maxn];
int check(int i,int j,double x){
    double dis=sqrt((a[i].x-a[j].x)*(a[i].x-a[j].x)+(a[i].y-a[j].y)*(a[i].y-a[j].y));

    if(dcmp(dis-x*2.0)<=0) return 1;
    else return 0;
}
int fa[maxn];
int find(int x){
    if(fa[x]==x) return x;
    return fa[x]=find(fa[x]);
}
void merge(int x,int y){
    int fx=find(x);
    int fy=find(y);
    fa[fx]=fy;
}
int main(){
    if(eps==0.00001) printf("1\n");
    int n,m,k;
    scanf("%d%d%d",&n,&m,&k);
    for(int i=1;i<=k;i++){
        scanf("%lf%lf",&a[i].x,&a[i].y);
    }
    double l=0,r=min(n,m);
    int t=100;
    while(t--){
        double x=(l+r)/2.0;
        for(int i=0;i<=k+1;i++){
            fa[i]=i;
        }
        for(int i=1;i<=k;i++){
            int flag=0;
            if(dcmp(1.0*m-a[i].y-x*2.0)<=0){
                merge(i,0);
                flag++;
            }
            if(dcmp(a[i].y-x*2.0)<=0){
                merge(k+1,i);
                flag++;
            }
            for(int j=i+1;j<=k;j++){
                if(check(i,j,x)){
                    merge(i,j);
                }
            }
            if(fa[find(0)]==fa[find(k+1)]){
                break;
            }
        }
        if(fa[find(0)]==fa[find(k+1)]) r=x;
        else l=x;
        if(dcmp(l-r)==0) break;
    }
    printf("%.4f\n",l);
    return 0;
}
/*

*/



#百度笔试##百度##笔试题目#
全部评论
第一题因为最小公倍数-最大公约数=a* b /最大公约数-最大公约数所以让最大公约数最小就是1 两个相邻的最大公约数就是1啊 a * b 也能最大
1 回复 分享
发布于 2020-03-29 21:13
😲 太强了
1 回复 分享
发布于 2020-03-29 21:12
QAQ,求个第三题题意😭
点赞 回复 分享
发布于 2020-03-30 11:39
第二题,题目可以同时出现两个0吗?这样也是先手输
点赞 回复 分享
发布于 2020-03-30 09:24
妙啊,第三题
点赞 回复 分享
发布于 2020-03-29 22:33
谢谢大佬,明白了
点赞 回复 分享
发布于 2020-03-29 21:17
哈哈,我说嘛,看你头像怎么这么熟
点赞 回复 分享
发布于 2020-03-29 21:13

相关推荐

但听说转正率很低,我现在有在实习了,好纠结要不要去
熬夜脱发码农:转正率低归低,但是实习的经历你可以拿着,又不是说秋招不准备了
点赞 评论 收藏
分享
06-27 12:54
已编辑
门头沟学院 Java
累了,讲讲我的大学经历吧,目前在家待业。我是一个二本院校软件工程专业。最开始选专业是觉得计算机感兴趣,所以选择了他。本人学习计算机是从大二暑假结束开始的,也就是大三开始。当时每天学习,我个人认为Java以及是我生活的一部分了,就这样持续学习了一年半,来到了大四上学期末,大概是在12月中旬,我终于找的到了一家上海中厂的实习,但我发现实习生的工作很枯燥,公司分配的活也不多,大多时间也是自己在自学。就这样我秋招末才找到实习。时间来到了3月中旬,公司说我可以转正,但是转正工资只有7000,不过很稳定,不加班,双休,因为要回学校参加答辩了,同时当时也是心高气傲,认为可以找到更好的,所以放弃了转正机会,回学校准备论文。准备论文期间就也没有投递简历。然后时间来到了5月中旬,这时春招基本也结束了,然后我开始投递简历,期间只是约到了几家下场面试。工资也只有6-7k,到现在我不知道该怎么办了。已经没有当初学习的心劲了,好累呀,但是又不知道该干什么去。在家就是打游戏,boss简历投一投。每天日重一次。26秋招都说是针对26届的人,25怎么办。我好绝望。要不要参加考公、考研、央国企这些的。有没有大佬可以帮帮我。为什么感觉别人找工作都是顺其自然的事情,我感觉自己每一步都在艰难追赶。八股文背了又忘背了又忘,我每次都花很长时间去理解他,可是现在感觉八股、项目都忘完了。真的已经没有力气再去学习了。图片是我的简历,有没有大哥可以指正一下,或者说我应该走哪条路,有点不想在找工作了。
码客明:太累了就休息一下兄弟,人生不会完蛋的
如果实习可以转正,你会不...
点赞 评论 收藏
分享
评论
4
21
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务