大厂2020届实习生笔试题
栏目: JavaScript · 发布时间: 5年前
内容简介:编程题:1.输入某年某月某日,判断这一天是这一年的第几天?2.寻找多数元素
编程题:
1.输入某年某月某日,判断这一天是这一年的第几天?
// 判断是否为闰年 function isRun(a) { return a % 4 == 0 && a % 100 != 0 || a % 400 == 0 } // 判断是这一年的第几天 function daysNum(year,month,day) { var months = [31,28,31,30,31,30,31,31,30,31,30,31]; if(month ==1) { return day; } for(var i = 0; i < month-1; i++) { day += months[i] } if(isRun(year) && month >2) { day ++ } return day }
2.寻找多数元素
设计一个方法,在一个数组中寻找占大多数的元素(如果存在的话),如果这样的元素不存在,就输出“没有元素占大多数”。
占大多数的元素的定义为:如果一个数组A的长度为n,某一个元素在数组中的数量大于n/2,这个元素即为占大多数的元素。(简单推理可知,一个数组最多有一个元素为占大多数的元素)
附加要求:时间复杂度越小越好
例子:
输入:[3,3,4,2,4,4,2,4,4]
输出: 4
// 一共5个4,超过数组长度的一半
[3,3,4,2,4,4,2,4,]
Output:没有元素占大多数
function SelectNum(arr) { let len = arr.length; var json = {}; for (let i = 0; i < len; i++) { if (json[arr[i]] == undefined) { json[arr[i]] = 1; } else { json[arr[i]] += 1 } } for (let a in json) { if (json[a] > len / 2) { return a } } return '没有元素占大多数' }
3.
请有缘人指点。。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux内核设计与实现
拉芙 / 陈莉君、唐华、张波 / 机械工业出版社 / 2006-1 / 38.00元
《Linux内核设计与实现》基于Linux2.6内核系列详细介绍Linux内核系统,覆盖了从核心内核系统的应用到内核设计与实现等各方面的内容。主要内容包括:进程管理、系统调用、中断和中断处理程序、内核同步、时间管理、内存管理、地址空间、调试技术等。本书理论联系实践,既介绍理论也讨论具体应用,能够带领读者快速走进Linux内核世界,真正开发内核代码。 本书适合作为高等院校操作系统课程的教材......一起来看看 《Linux内核设计与实现》 这本书的介绍吧!