2020阿里笔试编程题[通俗易懂]

2020阿里笔试编程题[通俗易懂]选择题很难做,阿里的秋招貌似非常难,大部分岗位都留给了实习生,但是两道编程题不怎么难。第一题有一个n*n的地图,一只兔子想要穿过这个地图,给出的地图是一个二维数组map[i][j],数值表示该位置的毒雾持续时间,当兔子在(x,y)位置时,它可以跳到(x+2,y)或者(x,y+2)位置,跳的时候需要对应等待map[x+1][y]或者map[x][y+1]的时间,兔子开始跳的位置从map[1][1…

大家好,又见面了,我是你们的朋友全栈君。

选择题很难做,阿里的秋招貌似非常难,大部分岗位都留给了实习生,但是两道编程题不怎么难。

第一题

有一个n*n的地图,一只兔子想要穿过这个地图,给出的地图是一个二维数组map[i][j],数值表示该位置的毒雾持续时间,当兔子在(x,y)位置时,它可以跳到(x+2,y)或者(x,y+2)位置,跳的时候需要对应等待map[x+1][y]或者map[x][y+1]的时间,兔子开始跳的位置从map[1][1…n]中选择,兔子到达第n行或者跳到了第n+1行均表示闯过了,求出兔子最少要花多少时间。(6<= n <= 30)
示例:
输入
6
1,2,3,5,7,6
2,1,4,5,7,4
3,4,5,6,3,6
2,3,1,4,6,8
5,6,1,4,6,2
4,2,4,1,1,6
输出
6

分析

深搜即可,但是不知道我的代码能不能全部跑过,感觉是不怎么难,深搜的参数是坐标(x,y),当y为n或n+1时记录当前时间,答案取最小时间即可。

代码

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
#define INF 0x3f3f3f3f
typedef long long LL;

int n,ti,ans;
int mp[31][31];

int dfs(int x,int y)
{ 
   
    if (x==n || x==n+1)
    { 
   
        ans = min(ti,ans);
        return 0;
    }

    ti += mp[x+1][y];
    dfs(x+2,y);
    ti -= mp[x+1][y];

    if (y < n-1){ 
   
        ti += mp[x][y+1];
        dfs(x,y+2);
        ti -= mp[x][y+2];
    }

    return 0;
}

int main()
{ 
   
    cin>>n;
    for (int i=1 ; i<=n ; i++){ 
   
        for (int j=1 ; j<n ; j++){ 
   
            scanf("%d,",&mp[i][j]);
        }
        scanf("%d",&mp[i][n]);
    }

    ans = INF;
    for (int i=1 ; i<=n ; i++){ 
   
        ti = 0;
        dfs(1,i);
    }
    cout<<ans<<endl;

    return 0;
}

第二题

有一群男孩(用’b’表示)和女孩(用’g’表示)围成了一个圈,这个圈由一串字符串给出,如bgbbbgg,这个字符串表示的圈中位置0是个男孩,位置6是个女孩,作为一个圈他们俩是挨着的。我们把身边女孩子特别多的男孩子称为快乐男孩,比如上面的位置0,他身边有三个女孩子,别的男孩子最多身边才俩女孩,所以这个是快乐男孩,现在想知道哪个是快乐男孩。
这题还有问题二,圈里连续的几个人被称为一个小团体,给出一个k,表示一个小团体里最多只能有k个女孩子,问这样的小团体里面最多能有几个男孩子?
示例
输入
bgbbbgbggbgbg
3
输出
6 6
示例解释:显然位置6的这个比身边有三个女孩子所以他是快乐男孩,bgbbb gbgg bgbg 小团体有三位女生和六位男生。

分析

这个模拟一下就好了,第一个问题找boy左右两边的girl的数量,往left遍历直到出现了新的boy,当left为0时下一个left为n-1,看一下当前left是否是初始boy,如果是说明圈里只有一个boy,可以不再往右边遍历,否则往right遍历直到出现了boy,当right为n-1时下一个right为0。
第二个问题先考虑女生数量少于等于k的情况,那么输出总共的男生数即可,否则,我的做法是先找到一个女生,这个女生不包括在小团体中,从这个位置往后算作小团体,数男生的数量和女生的数量,直到女生出现了k+1次的时候停止。

代码

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
#define INF 0x3f3f3f3f
typedef long long LL;

string ss;
int k,happyboy,maxgirl,maxboy;
int main()
{ 
   
    cin>>ss;
    cin>>k;
    int len = ss.length();
    maxgirl = 0; maxboy = 0;
    int le = 0,ri = 0,mov = 0;
    int sumgirl = 0, sumboy = 0;
    int gir = 0;
    for (int i=0 ; i<len ; i++)
    { 
   
        if (ss[i]=='b')
        { 
   
            sumgirl = 0;
            if (i==0) le = len-1;
            else le = i-1;
            if (i==len-1) ri = 0;
            else ri = i+1;
            while (ss[le]=='g')
            { 
   
                sumgirl++;
                if (le==0) le = len-1
                else le--;
            }
            if (le != i){ 
   
                while (ss[ri]=='g'){ 
   
                    sumgirl++;
                    if (ri==n-1) ri = 0;
                    else ri++;
                }
            }
            if (sumgirl > maxgirl)
            { 
   
                maxgirl = sumgirl;
                happyboy = i;
            }
        }

        else if (ss[i]=='g')
        { 
   
           gir++;
        }
    }

    if (gir <= k)
        maxboy = len-gir;
    else { 
   
        for (int i=0 ; i<len ; i++){ 
   
            int now = 0;
            if (ss[i]=='g'){ 
   
                sumboy = 0;
                if (i < len-1) mov = i+1;
                else mov = 0;
                while (now < k)
                { 
   
                    if (ss[mov] == 'g'){ 
   
                        now++;
                    }
                    else { 
   
                        sumboy++;
                    }
                    mov++;
                    if (mov==len) mov = 0;
                }
                while (ss[mov]=='b'){ 
   
                    sumboy++;
                    mov++;
                    if (mov==len) mov = 0;
                }
                if (sumboy > maxboy)
                { 
   
                    maxboy = sumboy;
                }
            }
        }
    }
    cout<<happyboy<<" "<<maxboy<<endl;

    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142331.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux 端口被进程多次占用,LINUX最好用查看端口占用并杀死(kill)的方式「建议收藏」

    Linux 端口被进程多次占用,LINUX最好用查看端口占用并杀死(kill)的方式

    2022年2月9日
    77
  • 基于单片机的功放protues_基于Proteus的音频放大器电路设计与仿真详解.doc[通俗易懂]

    基于单片机的功放protues_基于Proteus的音频放大器电路设计与仿真详解.doc[通俗易懂]毕业论文学生姓名尹有友学号171107078学院物理与电子电气工程学院专业电子信息工程题目基于Proteus的音频放大电路设计与仿真指导教师付浩副教授/学士2015年5月论文原创性声明内容本人郑重声明:本论文是我个人在导师指导下进行的研究工作及取得的研究成果。本论文除引文外所有实验、数据和有关材料均是真实的。尽我所知,除了文中特别加以标注和致谢的地方外…

    2022年6月6日
    34
  • ppt导出pdf后非矢量图图片失真的解决办法

    ppt导出pdf后非矢量图图片失真的解决办法背景明明有了高清的图片,为什么导入PPT后图像反而模糊了?导出pdf后图片更是惨不忍睹?今天为了解决这个问题,我又折腾了一会儿。准备AdobeAcrobatproPPTPhotoZoom获得高清图片一般用别的软件导出图片可以调节格式分辨率,采用矢量图或者分辨率高的位图就可以,然而从网上获取的图片就没办法了。这时候你需要一款经久不衰的神器,PhotoZoom。他界面是这样的,可以方便的

    2022年6月5日
    114
  • python读取excel文件显示文件不存在?_python写入excel文件

    python读取excel文件显示文件不存在?_python写入excel文件1、环境准备pipinstallxlrd导入xlrd2、读取Excel文件readfile=xlrd.open_workbook(r”E:\PycharmProjects\APITest\工作簿1.xls”)print(readfile)3、获取全部sheet名称#获取sheet名称names=readfile.sheet_names()print(names)4、选择所需要的sheet#获取sheet对象obj_sheet=readfile.shee

    2022年10月2日
    0
  • Win10自动更新怎么永久关闭?有效的Win10强制更新关闭方法

    Win10自动更新怎么永久关闭?有效的Win10强制更新关闭方法之前小编为大家分享过一些Win10彻底关闭WindowsUpdate自动更新的方法,主要是通过一些如设置流量计费或借助一些专门的小工具来实现,但往往会发现,Win10自动更新就像打不死的小强,不管怎么关闭,之后还是会自动更新,让不少小伙伴颇为不爽。今天小编带来了这篇改进型教程,通过全方位设置,彻底关闭Win10自动更新,感兴趣的小伙伴不妨试试吧。…

    2022年6月18日
    33
  • python 如何使用swagger

    swagger介绍swagger是一个api文档工具,集api管理,测试,访问于一体的网页版api文档工具了解更多,请访问相关网站swagger官网swaggergithubOpenApi参数说明python相关包connexionflasggerflask-swag,flask-swaggerFlask-RESTPluspythonswagger-cod…

    2022年4月12日
    696

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号