关于淘汰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条件来推断即可了,什么高大的算法也不用。。

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

 

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

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

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

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


相关推荐

  • Linux 设置固定IP地址

    Linux 设置固定IP地址当我们安装完linux之后需要做的第一件事就是配置网络,因为有了网络我们可以做更多的事,比如下载插件,使用xshell工具连接等等ifconfig查看网络配置,类似windows的ipconfiglinux的网络配置文件一般在/etc/sysconfig/network-scripts/下面,使用命令cd切换到该路径下其中ifcfg-eth0就是虚拟机桥接的网络配置,如果有无…

    2022年5月2日
    67
  • Groovy新手教程

    Groovy新手教程

    2021年12月1日
    38
  • 数据可视化之美 — 以Matlab、Python为工具

    数据可视化之美 — 以Matlab、Python为工具在我们科研、工作中,将数据完美展现出来尤为重要。数据可视化是以数据为视角,探索世界。我们真正想要的是—数据视觉,以数据为工具,以可视化为手段,目的是描述真实,探索世界。下面介绍一些数据可视化的作品(包含部分代码),主要是地学领域,可迁移至其他学科。Example1:importnumpyasnpimportmatplotlib.pyplotasplt#创建随机数n=100000x=np.random.randn(n)y=(1.5*x)+np.ra

    2025年6月15日
    2
  • 无法修复正在使用中的磁盘_硬盘无法正常弹出是什么原因

    无法修复正在使用中的磁盘_硬盘无法正常弹出是什么原因前段时间中了N次毒,重装了N次机器,在与病毒的战斗中损失惨重,在此哀悼为之牺牲的脑细胞和时间。以前遇到问题总想在网上找答案,也受到了很多帮助和启发。今天也把自己的心得写下来,供各位参考。fun.xle.exe是一种叫做U盘病毒tel.xls.exe的变种,会在电脑里注入文件:C:/Windows/System32/msfun80.exeC:/Windows/System32/msime82.exe

    2022年10月3日
    4
  • Linux 常用的系统信息查看命令

    Linux 常用的系统信息查看命令

    2021年6月8日
    173
  • kali虚拟机安装教程(超详细)

    kali虚拟机安装教程(超详细)一、官方下载KaliLinux官方网址:www.Kali.org下载方式分两种:http下载和bt下载(由于是国外网站http方式下载会非常慢),选择对应版本点击即可下载。二、创建新的虚拟1、新建虚拟机(使用自定义方式),点击”下一步“,然后选择自己所安装的虚拟机版本,再点击”下一步“;2、选择”稍后安装操作系统“,点击”下一步“,选择虚拟机可支持的Linux版本,这里使用Debian8.x,然后点击”下一步“;3、输入虚拟机名称并选择安装位置,点击”.

    2022年5月2日
    71

发表回复

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

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