-
Notifications
You must be signed in to change notification settings - Fork 1
/
review.html
75 lines (65 loc) · 23.5 KB
/
review.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en-us">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<meta name="renderer" content="webkit">
<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport"/>
<meta content="yes" name="apple-mobile-web-app-capable"/>
<meta content="black" name="apple-mobile-web-app-status-bar-style"/>
<meta content="telephone=no" name="format-detection"/>
<meta name="renderer" content="webkit"/>
<title>review</title>
<link rel="stylesheet" href="data:text/css;base64,
    h1, h2, h3, h5, h6,  img, svg, pre, table, tr, .md_line{page-break-inside: avoid}


    body {
        background: #171D21;
        font-size: 14px;
        line-height:2.3;
        font-family: "Helvetica";
        font-weight: normal;
        color: #A5B0C0;
        padding: 0 38px;
        max-width: 820px;
        margin: 0 auto;

        word-wrap:break-word;
        word-break: normal;
        overflow-wrap:break-word;


        overflow-x: hidden;
        text-rendering: optimizeLegibility;
        -webkit-text-size-adjust: none;
    }

    br{
        line-height: 2.3;
    }



    @media (max-width: 600px) {
        body{
            padding: 0 30px;
        }
    }

    @media (max-width: 480px) {
        body{
            padding: 0 20px;
        }
    }

    .gist{
        word-break: normal;
    }

    .post{
        margin-top: 10px;
        margin-bottom: 50px;
        position: relative;
    }



    img{
        max-width: 98%;
        margin: 0.8em auto 0.8em auto;
    }

    h1 img, h2 img, h3 img, h4 img, h5 img, h6 img{
        margin: auto;
    }

    .x2_image{
        zoom: 50%;
    }

    .x3_image{
        zoom: 33.33%;
    }

    .x4_image{
        zoom: 25%;
    }


    p img{
        margin: 0 auto;
    }

    p{
        /*overflow:hidden;*/
        margin: 1.0em 0 1.8em 0;
    }

    p.md_block_as_opening{
        margin-bottom: -0.5em !important;
    }

    li p{
        line-height: 2.07;
        margin: 0;
    }

    .p_part {
        margin: 10px 0;
    }

    .p_part p{
        margin: 0 0 0.6em 0;
    }

    /* text indent for chinese starts*/
    /*h2, h3, h4, h5, h6, .p_part p, .todo_item, p{
        text-indent: 0px;
    }*/
    table, pre, svg, .codehilitetable{
        margin-left: 0px;
        margin-right: 0px;
    }

    .codehilitetable pre{
        margin-left: 0;
        margin-right: 0;

    }

    .codehilitetable .codehilite pre{
        border-left: none;
    }

    /* text indent for chinese ends*/


    blockquote .p_part p, li .p_part p{
        text-indent: 0 !important;
    }


    hr{
        margin: 38px 0;
        border: none;
        border-bottom: 1px dashed rgba(205, 205, 205, 0.35);
        color: rgba(205, 205, 205, 0.35);
        height: 1px;
        line-height:1px;
        font-size:1px;
        overflow-y: hidden;
    }


    h1{
        color: #D5F0F8;
        font-size: 1.6em;
        text-align: left;
        margin: 0;
        padding: 0;
        line-height: 1.6em;
        margin-top: 0.8em;
        margin-bottom: 0.6em;
    }

    h1, h2, h3, h4{
        color: #D5F0F8;
    }


    h2, h3{
        line-height: 1.5em;
        margin-top: 1.8em;
        margin-bottom: 0.5em;
    }

    .h16.md_first_h.md_first_part {
        margin-top: 5px;
    }

    h2 {
        font-size: 1.35em;
    }

    h3 {
        font-size: 1.2em
    }

    h4 {
        font-size: 1.1em;
    }

    h5 {
        font-size: 1.15em;
    }

    h6 {font-size: 1em}


    h1, h2, h3, h4, h5, h6{
        font-family: "Heiti SC";
    }


    ol {
        margin: 0;
    }

    ul{
        padding: 5px 38px;
        margin: 0;
    }

    ul li, li{
        padding: 0;
        margin: 0;
    }

    ul p, ol p{
        overflow: visible;
    }


    blockquote {
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        margin: 1.6em 0;
        padding: 0 0 0 1.2em;
        border-left: 0.4em solid #4F555E;
        color: #9A9A9A;
        min-height:20px;
    }


    blockquote p {
        margin: 0.8em 0;
    }

    blockquote span.md_line {
        margin-bottom: 0.25em;
        margin-top: 0.25em;
    }

    blockquote ul{
        padding: 0 15px;
    }

    blockquote small {
        display: inline-block;
        margin: 0.8em 0 0.8em 1.5em;
        font-size: 0.9em;
        color: #ccc;
    }






    table {
        line-height: 1.7;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        margin: 1em 0;
        width: 100%;
        max-width: 100%;
        border-width: 1px;
        border-style: solid;
        background-color: transparent;
        border-spacing: 0;
        word-break: normal;
    }
    
    /* for wechat only starts */
    table tr{
        border-right-style: solid;
        border-right-width: 1px;
    }
    
    table tbody{
        border-bottom-width: 1px;
        border-bottom-style: solid;
    }
    /* for wechat only ends */


    table, table tr, table tr td, table tr th, table tbody {
        border-color: rgba(205, 205, 205, 0.35);
    }

    table th {
        font-weight: bold;
    }

    tr th {
        border-bottom-width: 1px;
        border-bottom-style: solid;
        text-align: left;
    }

    tr th, tr td {
        padding: 10px 20px;
        border-right: 1px solid;
        border-bottom: 1px solid rgba(205, 205, 205, 0.35);
    }

    tbody tr:last-child td{
        border-bottom: 0;
    }

    tr th:last-child, tr td:last-child {
        border-right: 0;
    }

    table tbody > tr:nth-child(odd) > td, table tbody > tr:nth-child(odd) > th {
        background-color: rgba(235, 235, 235, 0.2);
    }




    code{
        background: rgba(235, 235, 235, 0.35);
        color: #78E291;
        padding: 0 5px;
        margin: 0 2px;
    }

    pre{
        margin-top: 1.2em;
        margin-bottom: 1.2em;
        padding: 15px 10px;
        display: block;
        /* overflow: auto; */
        border: 1px solid rgba(205, 205, 205, 0.35);
        /*background: rgba(235, 235, 235, 0.35);*/
        font-size: 90%;
        line-height:2.3;
        white-space: pre-wrap;
    }

    .highlighttable td{
        /*background-color: rgba(235, 235, 235, 0.35) !important;*/
    }

    .with_lines pre{
        border:none;
        margin-top: 0.2em;
        margin-bottom: 0.2em;
        background: transparent;
    }

    .is_code_file pre{
        border: none;
        background: transparent;
    }

    .codehilite pre{
        /*word-wrap: normal;*/
        font-size: 13px;
    }

    pre code{
        border:none;
        background: none;
        padding: 0;
        margin: 0;
    }

    pre p{
        margin: 0;
        padding: 0;
    }

    .codehilite th, .codehilite td{
        line-height: 1.8em;
    }


    a{
        color: #77B87F;
        text-decoration: none;
        //border-bottom: 1px solid transparent;
    }

    a:hover{
        text-decoration: underline;
        //border-bottom: 1px solid #77B87F;
    }

    strong {
        color: #FFFFFF;
        font-weight: bold;
    }


    /* for markdown */

    .linenos pre{
		background: transparent;
		border: none;
	}

	.linenos{
	    padding: 0 5px 0 5px;
	    width: 0.001%;
	}

	.highlighttable pre{
	    padding: 5px 10px;
	}

    .toc{
        background: None;
        border-radius: 5px;
        border: 1px solid None;
        margin: 27px 0 47px 0;
        padding: 10px 0;
    }

    .toc ul{
        //padding: 5px 42px;
    }

    .toc ul li{
        padding: 0;
        margin: 0;
    }
    .toc a{
        color: #A5B0C0;
    }



    .todo_item{
        list-style: none;
        margin-left: -1.5em
    }
    .todo_item .todo_item {
        margin-left: auto;
    }

    .todo_done_item{
        color: #555555;
    }

    .todo_undone_item{
        color: #DDDDDD;
    }


    ul li.todo_item{
	list-style-type: none;
    }

    ul li.todo_item:before{
        content: '☐';
        /*padding-right: 0.2em;*/
        font-family: arial;
    }

    ul li.todo_done_item:before{
        content: '☑';
        /*padding-right: 0.2em;*/
        font-family: arial;
    }

    ul li.todo_item input{
        display:none
    }


    /*pygments*/

    .codehilite{
        background: transparent !important;
    }

    table.codehilitetable{ border:none; }


    .codehilitetable td{ border: none; padding: 0;}

    .flow-graphic, .md_block_section_for_flow_graphic{text-align: center}
    .flow-graphic { overflow-x: auto;}
    .mermaid, .md_block_section_for_mermaid{text-align: center}


    table, tr, td, th, tbody, thead, tfoot, .md_echarts, blockquote .md_line{
        page-break-inside: avoid !important;
    }

    .footnotes .md_line{
        display: inline !important;
    }


    .img_rt_90{
        transform:rotate(90deg);
        -ms-transform:rotate(90deg);
        -moz-transform:rotate(90deg);
        -webkit-transform:rotate(90deg);
        -o-transform:rotate(90deg);
    }
    .img_rt_180{
        transform:rotate(180deg);
        -ms-transform:rotate(180deg);
        -moz-transform:rotate(180deg);
        -webkit-transform:rotate(180deg);
        -o-transform:rotate(180deg);
    }
    .img_rt_270{
        transform:rotate(270deg);
        -ms-transform:rotate(270deg);
        -moz-transform:rotate(270deg);
        -webkit-transform:rotate(270deg);
        -o-transform:rotate(270deg);
    }

    .md_has_block_below{
        margin-bottom: 0.1em !important;
    }
    .md_has_block_below_img{
        margin-bottom: -0.6em !important;
    }


    .codehilite .err{
        border: none !important;
    }



        span.md_line{margin-bottom:0.5em; display:block; line-height:1.9895}
        .md_line br{ display: none;}
        .codehilite .hll { background-color:  }
.codehilite  { background: #272822; color: #f8f8f2 }
.codehilite .c { color: #75715e } /* Comment */
.codehilite .err { color: #960050; background-color: #1e0010 } /* Error */
.codehilite .k { color: #66d9ef } /* Keyword */
.codehilite .l { color: #ae81ff } /* Literal */
.codehilite .n { color: #f8f8f2 } /* Name */
.codehilite .o { color: #f92672 } /* Operator */
.codehilite .p { color: #f8f8f2 } /* Punctuation */
.codehilite .ch { color: #75715e } /* Comment.Hashbang */
.codehilite .cm { color: #75715e } /* Comment.Multiline */
.codehilite .cp { color: #75715e } /* Comment.Preproc */
.codehilite .cpf { color: #75715e } /* Comment.PreprocFile */
.codehilite .c1 { color: #75715e } /* Comment.Single */
.codehilite .cs { color: #75715e } /* Comment.Special */
.codehilite .gd { color: #f92672 } /* Generic.Deleted */
.codehilite .gi { color: #a6e22e } /* Generic.Inserted */
.codehilite .gu { color: #75715e } /* Generic.Subheading */
.codehilite .kc { color: #66d9ef } /* Keyword.Constant */
.codehilite .kd { color: #66d9ef } /* Keyword.Declaration */
.codehilite .kn { color: #f92672 } /* Keyword.Namespace */
.codehilite .kp { color: #66d9ef } /* Keyword.Pseudo */
.codehilite .kr { color: #66d9ef } /* Keyword.Reserved */
.codehilite .kt { color: #66d9ef } /* Keyword.Type */
.codehilite .ld { color: #e6db74 } /* Literal.Date */
.codehilite .m { color: #ae81ff } /* Literal.Number */
.codehilite .s { color: #e6db74 } /* Literal.String */
.codehilite .na { color: #a6e22e } /* Name.Attribute */
.codehilite .nb { color: #f8f8f2 } /* Name.Builtin */
.codehilite .nc { color: #a6e22e } /* Name.Class */
.codehilite .no { color: #66d9ef } /* Name.Constant */
.codehilite .nd { color: #a6e22e } /* Name.Decorator */
.codehilite .ni { color: #f8f8f2 } /* Name.Entity */
.codehilite .ne { color: #a6e22e } /* Name.Exception */
.codehilite .nf { color: #a6e22e } /* Name.Function */
.codehilite .nl { color: #f8f8f2 } /* Name.Label */
.codehilite .nn { color: #f8f8f2 } /* Name.Namespace */
.codehilite .nx { color: #a6e22e } /* Name.Other */
.codehilite .py { color: #f8f8f2 } /* Name.Property */
.codehilite .nt { color: #f92672 } /* Name.Tag */
.codehilite .nv { color: #f8f8f2 } /* Name.Variable */
.codehilite .ow { color: #f92672 } /* Operator.Word */
.codehilite .w { color: #bbbbbb } /* Text.Whitespace */
.codehilite .mb { color: #ae81ff } /* Literal.Number.Bin */
.codehilite .mf { color: #ae81ff } /* Literal.Number.Float */
.codehilite .mh { color: #ae81ff } /* Literal.Number.Hex */
.codehilite .mi { color: #ae81ff } /* Literal.Number.Integer */
.codehilite .mo { color: #ae81ff } /* Literal.Number.Oct */
.codehilite .sa { color: #e6db74 } /* Literal.String.Affix */
.codehilite .sb { color: #e6db74 } /* Literal.String.Backtick */
.codehilite .sc { color: #e6db74 } /* Literal.String.Char */
.codehilite .dl { color: #e6db74 } /* Literal.String.Delimiter */
.codehilite .sd { color: #e6db74 } /* Literal.String.Doc */
.codehilite .s2 { color: #e6db74 } /* Literal.String.Double */
.codehilite .se { color: #ae81ff } /* Literal.String.Escape */
.codehilite .sh { color: #e6db74 } /* Literal.String.Heredoc */
.codehilite .si { color: #e6db74 } /* Literal.String.Interpol */
.codehilite .sx { color: #e6db74 } /* Literal.String.Other */
.codehilite .sr { color: #e6db74 } /* Literal.String.Regex */
.codehilite .s1 { color: #e6db74 } /* Literal.String.Single */
.codehilite .ss { color: #e6db74 } /* Literal.String.Symbol */
.codehilite .bp { color: #f8f8f2 } /* Name.Builtin.Pseudo */
.codehilite .fm { color: #a6e22e } /* Name.Function.Magic */
.codehilite .vc { color: #f8f8f2 } /* Name.Variable.Class */
.codehilite .vg { color: #f8f8f2 } /* Name.Variable.Global */
.codehilite .vi { color: #f8f8f2 } /* Name.Variable.Instance */
.codehilite .vm { color: #f8f8f2 } /* Name.Variable.Magic */
.codehilite .il { color: #ae81ff } /* Literal.Number.Integer.Long */
    /* page_css */

    
    html{
        background: #10161A;
    }
    body{
        width: 90%;
        max-width: 960px;
        background: #171D21;
        margin: 3em auto 0;
        padding-top: 2em;
        border: 1px solid #10161A;
        border-width: 0 1px;
    }

    .post{
        padding: 5% 10%;
        margin-top: 0;
        margin-bottom: 0;
    }
    

    .title_container{
        margin: -2em 0 3.5em;
        padding-bottom: 2em;
        border-bottom: 3px double #10161A;
    }
    .title_container h1{
        margin-top: 1.2em;
        margin-bottom: 0.6em;
        line-height: 1.35;
        font-size: 2.25em;
    }
    .title_container h2{
        color: #9A9A9A;
        font-size: 1em;
        font-weight: normal;
        padding-bottom: 2em;
        line-height: 1.35;
        margin-bottom: -2em;
    }

    @media only screen and (max-width: 760px){
        html{
            background: transparent;
        }
        body{
            margin: 0;
        }
        .post{
            padding: 0;
        }
    }
    /* page_css */

    ">
<!--header_scripts-->
</head>
<body>
<div class="post">
<div class="post_body">
<h2 id="toc_0" class="h16 md_first_h">拼多多——AI引擎方向</h2>
<h3 id="toc_1" class="h16">一面</h3>
<p class="md_block">
<span class="md_line md_line_start">面试基本上都围绕项目,特别是笔者用Flink做的用户实时推荐。。。<br /></span>
<span class="md_line md_line_dom_embed"><strong>笔试题</strong><br /></span>
<span class="md_line">1) 求n的平方根(向下取整,禁止用函数)<br /></span>
<span class="md_line">比较简单就不贴代码了,考虑效率问题,可以用二分查找来实现<br /></span>
<span class="md_line">2) g(x)函数输出1、2、3、4、5的概率都是1/5,现在要求p(x)函数使用g(x)函数,使p(x)输出1、2、3的概率都是1/3<br /></span>
<span class="md_line md_line_end">这种题目都不难,只要抓住面试官想考察的重点即可,就这道题来说,不必理会具体的概率,只要p(x)调用g(x)获取到4或者5,就再次调g(x)重试,直到输出结果是1、2、3,伪代码如下:</span>
</p>
<div class="codehilite code_lang_java highlight"><pre><span></span><span class="kt">int</span> <span class="nf">a</span><span class="o">(</span><span class="n">x</span><span class="o">)</span> <span class="o">{</span>
<span class="kt">int</span> <span class="n">x</span> <span class="o">=</span> <span class="n">g</span><span class="o">(</span><span class="n">x</span><span class="o">);</span>
<span class="n">whiile</span> <span class="o">(</span><span class="n">x</span> <span class="o">></span> <span class="mi">3</span><span class="o">)</span> <span class="o">{</span>
<span class="n">x</span> <span class="o">=</span> <span class="n">g</span><span class="o">(</span><span class="n">x</span><span class="o">)</span>
<span class="o">}</span>
<span class="k">return</span> <span class="n">x</span><span class="o">;</span>
<span class="o">}</span>
</pre></div>
<!--block_code_end--><h3 id="toc_2" class="h16">二面</h3>
<p class="md_block">
<span class="md_line md_line_dom_embed md_line_start"><strong>面试题</strong><br /></span>
<span class="md_line">面试同样是问Flink项目,项目背景、项目流程、存入redis如何优化,<br /></span>
<span class="md_line md_line_dom_embed"><strong>笔试题</strong><br /></span>
<span class="md_line">1) 自己实现一个队列,包含push和pop方法<br /></span>
<span class="md_line md_line_end">笔者先用单链表实现了一个,pop的时候需要遍历链表,效率较低,后来在面试中又改进了一版,加了tail节点,并采用双向链表实现,保证pop的复杂度为O(1),伪代码如下:</span>
</p>
<div class="codehilite code_lang_java highlight"><pre><span></span><span class="kd">public</span> <span class="n">T</span> <span class="nf">pop</span><span class="o">()</span> <span class="o">{</span>
<span class="n">T</span> <span class="n">value</span> <span class="o">=</span> <span class="n">tail</span><span class="o">.</span><span class="na">value</span><span class="o">;</span>
<span class="n">Node</span> <span class="n">preNode</span> <span class="o">=</span> <span class="n">tail</span><span class="o">.</span><span class="na">pre</span><span class="o">;</span>
<span class="n">tail</span> <span class="o">=</span> <span class="n">preNode</span><span class="o">;</span>
<span class="n">preNode</span><span class="o">.</span><span class="na">next</span> <span class="o">=</span> <span class="kc">null</span><span class="o">;</span>
<span class="n">reyutn</span> <span class="n">value</span><span class="o">;</span>
<span class="o">}</span>
</pre></div>
<!--block_code_end-->
<p class="md_block">
<span class="md_line md_line_start md_line_end">做完之后,面试官没说什么,只是让我等一下,然后 and 然后。。。,HR就来了,然后就被告知面试未通过,说技术栈不符合他们的要求,真是一脸懵逼啊(不符合你们技术栈,还让我来面试。。)</span>
</p>
<h3 id="toc_3" class="h16">总结</h3>
<p class="md_block">
<span class="md_line md_line_start md_line_end">拼多多给笔者感觉太注重业务,也可能是技术栈不符合人家要求,人家也不知道怎么问</span>
</p>
</div>
</div>
<!--mathjax-->
<!--mermaid-->
</body>
</html>