牛客网字节跳动面试题解析

Python060

牛客网字节跳动面试题解析,第1张

1)

题目给出的初始值是在计算机存储形式,即补码形式。a为负数,b为整数。

a-b = a + (-b)——思路是先得到(-b)的补码形式,然后将a的补码与(-b)的补码相加。

a的补码题目已给出: 0xF000000000000000

-b的原码:0xFFFFFFFFFFFFFFFF

-b的反码:0x8000000000000000

-b的补码:0x8000000000000001

a-b = 0xF000000000000000 + 0x8000000000000001

      = 0x7000000000000001

      =  2^62 + 2^61 + 2^60 + 1

负数-正数 = 正数?这是因为计算机存储字节长度的限制导致的最高位溢出。

2)

Boolean([]) //true

布尔类型里只有这几参数个返回false,其它都为true

Boolean(undefined) // false

Boolean(null) // false

Boolean(0) // false

Boolean(NaN) // false

Boolean('') // false

布尔类型与其它任何类型进行比较,布尔类型将会转换为number类型。

Number([])返回0所以第二题为true

Number转换类型的参数如果为对象返回的就是NaN,

那么Number({})返回的就是NaN。

通过Object.prototype.toString.call({})来判断类型,0与NaN相比为false

所以 true  true false

3)

块元素

address - 地址

blockquote - 块引用

center - 举中对齐块

dir - 目录列表

div - 常用块级容易,也是css layout的主要标签

dl - 定义列表

fieldset - form控制组

form - 交互表单

h1 - 大标题

h2 - 副标题

h3 - 3级标题

h4 - 4级标题

h5 - 5级标题

h6 - 6级标题

hr - 水平分隔线

isindex - input prompt

menu - 菜单列表

noframes - frames可选内容6)

一、无继承性的属性

1、display:规定元素应该生成的框的类型

2、文本属性:

vertical-align:垂直文本对齐

text-decoration:规定添加到文本的装饰

text-shadow:文本阴影效果

white-space:空白符的处理

unicode-bidi:设置文本的方向

3、盒子模型的属性:width、height、margin 、margin-top、margin-right、margin-bottom、margin-left、border、border-style、border-top-style、border-right-style、border-bottom-style、border-left-style、border-width、border-top-width、border-right-right、border-bottom-width、border-left-width、border-color、border-top-color、border-right-color、border-bottom-color、border-left-color、border-top、border-right、border-bottom、border-left、padding、padding-top、padding-right、padding-bottom、padding-left

4、背景属性:background、background-color、background-image、background-repeat、background-position、background-attachment

5、定位属性:float、clear、position、top、right、bottom、left、min-width、min-height、max-width、max-height、overflow、clip、z-index

6、生成内容属性:content、counter-reset、counter-increment

7、轮廓样式属性:outline-style、outline-width、outline-color、outline

8、页面样式属性:size、page-break-before、page-break-after

9、声,(对于不支持frame的浏览器显示此区块内容

noscript - )可选脚本内容(对于不支持script的浏览器显示此内容)

ol - 排序表单

p - 段落

pre - 格式化文本

table - 表格

ul - 非排序列表

4)

通过iframe设置document.domain可以实现跨域

5)

ES6

A:类必须使用new调用,否则会报错。这是它跟普通构造函数的一个主要区别,后者不用new也可以执行。

B:export命令规定的是对外的接口,必须与模块内部的变量建立一一对应关系。

// 报错

export 1

// 报错

var m = 1

export m

上面两种写法都会报错,因为没有提供对外的接口。第一种写法直接输出 1,第二种写法通过变量m,还是直接输出 1。1只是一个值,不是接口。正确的写法是下面这样。

// 写法一

export var m = 1

// 写法二

var m = 1

export {m}

// 写法三

var n = 1

export {n as m}

D:A模块对外暴露了一个对象,引入的时候需要使用解构赋值

上面两种写法都会报错,因为没有提供对外的接口。第一种写法直接输出 1,第二种写法通过变量m,还是直接输出 1。1只是一个值,不是接口。正确的写法是下面这样。

import {readFile} from ‘A'

6)

一、无继承性的属性

1、display:规定元素应该生成的框的类型

2、文本属性:

vertical-align:垂直文本对齐

text-decoration:规定添加到文本的装饰

text-shadow:文本阴影效果

white-space:空白符的处理

unicode-bidi:设置文本的方向

3、盒子模型的属性:width、height、margin 、margin-top、margin-right、margin-bottom、margin-left、border、border-style、border-top-style、border-right-style、border-bottom-style、border-left-style、border-width、border-top-width、border-right-right、border-bottom-width、border-left-width、border-color、border-top-color、border-right-color、border-bottom-color、border-left-color、border-top、border-right、border-bottom、border-left、padding、padding-top、padding-right、padding-bottom、padding-left

4、背景属性:background、background-color、background-image、background-repeat、background-position、background-attachment

5、定位属性:float、clear、position、top、right、bottom、left、min-width、min-height、max-width、max-height、overflow、clip、z-index

6、生成内容属性:content、counter-reset、counter-increment

7、轮廓样式属性:outline-style、outline-width、outline-color、outline

8、页面样式属性:size、page-break-before、page-break-after

9、声音样式属性:pause-before、pause-after、pause、cue-before、cue-after、cue、play-during

二、有继承性的属性

1、字体系列属性

font:组合字体

font-family:规定元素的字体系列

font-weight:设置字体的粗细

font-size:设置字体的尺寸

font-style:定义字体的风格

font-variant:设置小型大写字母的字体显示文本,这意味着所有的小写字母均会被转换为大写,但是所有使用小型大写字体的字母与其余文本相比,其字体尺寸更小。

font-stretch:对当前的 font-family 进行伸缩变形。所有主流浏览器都不支持。

font-size-adjust:为某个元素规定一个 aspect 值,这样就可以保持首选字体的 x-height。

2、文本系列属性

text-indent:文本缩进

text-align:文本水平对齐

line-height:行高

word-spacing:增加或减少单词间的空白(即字间隔)

letter-spacing:增加或减少字符间的空白(字符间距)

text-transform:控制文本大小写

direction:规定文本的书写方向

color:文本颜色

3、元素可见性:visibility

4、表格布局属性:caption-side、border-collapse、border-spacing、empty-cells、table-layout

5、列表布局属性:list-style-type、list-style-image、list-style-position、list-style

6、生成内容属性:quotes

7、光标属性:cursor

8、页面样式属性:page、page-break-inside、windows、orphans

9、声音样式属性:speak、speak-punctuation、speak-numeral、speak-header、speech-rate、volume、voice-family、pitch、pitch-range、stress、richness、、azimuth、elevation

三、所有元素可以继承的属性

1、元素可见性:visibility

2、光标属性:cursor

四、内联元素可以继承的属性

1、字体系列属性

2、除text-indent、text-align之外的文本系列属性

五、块级元素可以继承的属性

1、text-indent、text-align

7)

将一个数组调整为最大堆.

根据堆的性质, 只要保证部分有序即可, 即根节点大于左右节点的值. 将数组抽象为一个完全二叉树, 所以只要从最后一个非叶子节点向前遍历每一个节点即可. 如果当前节点比左右子树节点都大, 则已经是一个最大堆, 否则将当前节点与左右节点较大的一个交换, 并且交换过之后依然要递归的查看子节点是否满足堆的性质, 不满足再往下调整. 如此即可完成数组的堆化.

8)

http请求方法(get、post区别)

1、本质区别:get用于查询信息(查),post用于插入信息(插);

2、安全性:对于服务器讲,get是安全(不更改信息)、幂等(作用1次和n次效果相同)post不安全、不幂等 

对于客户端将,get参数直接暴露在URL, 不安全;post参数放消息体中,更安全;

3、传送长度:  get受 URL限制,传送数据量小post传送数据量大,默认不受限制   

4、缓存机制、历史记录:get请求会被浏览器主动缓存,也会被保留在历史记录中,post都不可以;

5、数据类型:get只允许ASCII码字符类型,post无限制;

9)

属于JavaScript的typeof运算符的可能结果

10)

条件概率

男,周二:1/14

男,非周二:6/14

女,周二:1/14

女,非周二:6/17

两个孩子至少一个是周二生的男孩:1/14+1/14-1/14*1/14=27/196

两个孩子都是男孩且至少一个是周二生的:1/14*1/14+1/14*6/14+6/14*1/14=13/196

条件概率:13/27

12)

14)

关于下列CSS选择器:ID选择器、类选择器、伪类选择器、标签名称选择器,排序正确的是

ID选择器>Class选择器=伪类>标签名称选择器

15)

假设两线程为A、B,设有3种情况:

1.AB不并发:此时相当于两个方法顺序执行。A执行完后a=-1,B使用-1作为a的初值,B执行完后a=-2

2.AB完全并发:此时读写冲突,相当于只有一个线程对a的读写最终生效。相同于方法只执行了一次。此时a=-1

3.AB部分并发:假设A先进行第一次读写,得到a=1之后A的读写被B覆盖了。B使用用1作为a的初值,B执行完后a=0

如果先匹配32 那么如果他是第二趟的话 32右边应该为60 72 如果先匹配12 那么第二趟的这个序列左边应该为2 5 快排每一趟都是把左右两边都排一遍 很显然这个序列不是第二趟(不是左边没排就是右边没排)

是的。

华为机试基本上都是考编程。以2012年华为南京地区校园招聘软件类上机考试为例。那年的软件研发类岗位(软件研发、云计算、操作系统开发、数据库开发)需要提前进行上机考试。题目类别包括C/C++、Java两个类别,根据个人情况选作一个类别。每个考生有三道题,第一二道题必答,第三道题为附加题可以选作,附加题做出,成绩会计入总分。