关于淘汰85%查看面试官百度开发者面对的问题

关于淘汰85%查看面试官百度开发者面对的问题

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

刚在网上看到一篇文章。标题为 一道淘汰85%面试者的百度开发人员面试题。感觉好难的样子,就默默的进去看了一下。首先来看一下原题吧。

作者:王奎      博客:www.marksaas.com

题目描写叙述:

依序遍历0到100闭区间内全部的正整数,假设该数字能被3整除,则输出该数字及‘*’标记。假设该数字能被5整除,则输出该数字及‘#’标记;假设该数字既能被3整除又能被5整除,则输出该数字及‘*#’标记。

提示:

这道看似很easy的题目。却潜藏着几个玄机。面试官通过这道题,考察学生在语法、语义、语用以及算法优化方面的能力。

现实告诉我们,通过这一道题目,就能够淘汰85%的面试者。看似残酷的考察方式,却也体现出学生在基础知识、动手能力到思维能力上的差距。

须要注意的考察点:

– 语法:语法的正确书写。包含格式
– 语义:对循环、分支等语义的理解与掌握
– 语用:对变量命名、表达式及语句的组合使用
– 算法优化:假设要提高执行效率。能够在算法上寻找突破口,也能够採用空间换时间的通用原则。

猛一看题目确实不难,但easy犯晕,我的第一思路是直接三个if语言搞定,但细致想想会有反复输出。比如,15能被3和5整除,推断的时候就会出问题。可是自学拍一下if语句就没啥问题了,比如,把推断既能被3整除又能被5整除放在一个条件推断,以下来看一下详细的代码吧。

/*
	@author marksaas
	@blog www.marksaas.com
	@time 2014-4-24
	timu依序遍历0到100闭区间内全部的正整数,假设该数字能被3整除。则输出该数字及‘*’标记。
	假设该数字能被5整除。则输出该数字及‘#’标记;假设该数字既能被3整除又能被5整除。则输出该数字及‘*#’标记。

*/public class Baidu{ public static void main(String[] args){ for(int i=1;i<100;i++){ if(i%3==0&&i%5==0){ System.out.println(i+"*#"); }else if(i%3==0){ System.out.println(i+"*"); }else if(i%5==0){ System.out.println(i+"#"); } } }}

第二个思路是先推断一下能否被3整除。在内层循环中再推断能否被5整除,假设能就输出,当然首先要定义一个中间量。。还是直接看代码easy理解。

。。

/*
	@author marksaas
	@blog www.marksaas.com
	@time 2014-4-24
	timu依序遍历0到100闭区间内全部的正整数,假设该数字能被3整除,则输出该数字及‘*’标记;
	假设该数字能被5整除。则输出该数字及‘#’标记;假设该数字既能被3整除又能被5整除,则输出该数字及‘*#’标记。
*/
public class Baidu{
	public static void Print(){
		String result="";
		for(int i=1;i<=100;i++){
			if(i%3==0){
				result=i+"*";
				if(i%5==0){
					result+="#";
				}
				System.out.println(result);
				continue;
			}else if(i%5==0){
				result=i+"#";
				System.out.println(result);
			}

		}

	}
	public static void main(String[] args){
		Print();
	}
}

感觉这道题就用if条件来推断即可了,什么高大的算法也不用。。

假设有更好的思路,欢迎探讨。请看关于本站 

 

版权声明:本文博客原创文章,博客,未经同意,不得转载。

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/117630.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • windows10安装虚拟机步骤_vmware虚拟机安装win7

    windows10安装虚拟机步骤_vmware虚拟机安装win7**windows10安装虚拟机详细教程****1.安装环境:**windows10**2.安装所需要用到的材料:**材料链接:https://pan.baidu.com/s/1usn2tAPPV3YvAc8NSF9pfg提取码:d6uf(复制这段链接后打开百度网盘手机App,操作更方便哦,想要其他版本的话就去官网下载,操作大同小异)**3.安装步骤:**(1)双击下图文件。(2)弹出下图,点击”下一步”即可。(3)点击“更改”安装位置,可以不用进行修改,本人安装

  • 【VS开发】socket编程原理

    【VS开发】socket编程原理socket编程原理1、问题的引入1)普通的I/O操作过程:UNIX系统的I/O命令集,是从Maltics和早期系统中的命令演变出来的,其模式为打开一读/写一关闭(open-write-read-close)。在一个用户进程进行I/O操作时,它首先调用“打开”获得对指定文件或设备的使用权,并返回称为文件描述符的整型数,以描述用户在打开的文件或设备上

    2022年10月17日
  • php sql filestream,FileStream应用

    php sql filestream,FileStream应用FileStream:文件流,为了解决大对象BLOB(BinaryLargeObjects)的存储问题.对于大对象存储,并且不受2GB的限制.以往有两种方式:(1)存储在数据库里面,这种方式一般使用image字段,或者varbinary(max)来做,好处是可以统一备份,但实际效率较低;(2)存储在文件系FileStream:文件流,为了解决大对象BLOB(BinaryLargeOb…

  • StringUtils函数全集「建议收藏」

    StringUtils函数全集「建议收藏」StringUtils中方法的操作对象是java.lang.String类型的对象,是JDK提供的String类型操作方法的补充,并且是null安全的(即如果输入参数String为null则不会抛出NullPointerException,而是做了相应处理,例如,如果输入为null则返回也是null等,具体可以查看源代码)。除了构造器,StringUtils中一共有130多个方法…

  • Linux开放指定端口命令

    Linux开放指定端口命令1.方式一1、开启防火墙systemctlstartfirewalld2、开放指定端口(比如1935端口)firewall-cmd–zone=public–add-port=1935/tcp–permanent命令含义:–zone#作用域–add-port=1935/tcp#添加端口,格式为:端口/通讯协议–permanent#永久生效,没有此参数重启后失效3、重启防火墙firewall-cmd–reload4、查看..

  • Windows下的labelme数据标注工具安装教程[通俗易懂]

    Windows下的labelme数据标注工具安装教程[通俗易懂]前言因为最近要做一个目标检测的比赛,需要用到labelme这款开源标注工具,所以安装了下具体的的安装步骤可参考:https://github.com/wkentaro/labelme因为我是在Windows下使用的,所以这里只介绍了Windows的安装方法,Ubuntu、macOS等其他系统在上面的github都有详细介绍,大家自行查看哈 一、安装AnacondaWindo…

发表回复

您的电子邮箱地址不会被公开。

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