Linux迷+Python粉 - 面试https://blog.pythonwood.com/2020-06-22T00:00:00+08:00面试算法编程选记2题之二分法-寻找斜率为K的2点2020-06-22T00:00:00+08:002020-06-22T00:00:00+08:00pythonwoodtag:blog.pythonwood.com,2020-06-22:/2020/06/面试算法编程选记2题之二分查-寻找斜率为K的2点/<p>因为一直是用自学+坚持自学方法走过来的,折腾技术运用还可以,基础算法编程能力一直偏弱。</p> <p>1、二分法属于思维简单,细节弄人的典型。之前陷入过二分法脑风暴中不能通透,这次趁面试遇到好好再过一次,提高深度。</p> <p>2、输入数组A 例如&nbsp;[(x1,y1),(x2,y2)&hellip;],输出斜率为K的点对数目</p> <h3 id="_1">二分查找<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3> <p>二分查找要处理好中点 …</p><p>因为一直是用自学+坚持自学方法走过来的,折腾技术运用还可以,基础算法编程能力一直偏弱。</p> <p>1、二分法属于思维简单,细节弄人的典型。之前陷入过二分法脑风暴中不能通透,这次趁面试遇到好好再过一次,提高深度。</p> <p>2、输入数组A 例如&nbsp;[(x1,y1),(x2,y2)&hellip;],输出斜率为K的点对数目</p> <h3 id="_1">二分查找<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3> <p>二分查找要处理好中点,缩小方法,避免死循环。重在细节实现。&nbsp;Plus增强后支持最左最右查找</p> <p>已过 leetcode算法题:<a href="https://www.nowcoder.com/questionTerminal/28d5a9b7fc0b4a078c9a6d59830fb9b9">https://www.nowcoder.com/questionTerminal/28d5a9b7fc0b4a078c9a6d59830fb9b9</a></p> <div class="highlight"><pre><span></span><span class="s s-Atom">class</span> <span class="nv">BinarySearch</span><span class="s s-Atom">:</span> <span class="s s-Atom">def</span> <span class="nf">getPos</span><span class="p">(</span><span class="s s-Atom">self</span><span class="p">,</span> <span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="p">,</span> <span class="s s-Atom">val</span><span class="p">)</span><span class="s s-Atom">:</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="o">-</span><span class="mi">1</span> <span class="s s-Atom">#</span> <span class="s s-Atom">a1</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="s s-Atom">n</span><span class="o">-</span><span class="mi">1</span><span class="p">;</span> <span class="s s-Atom">while</span> <span class="s s-Atom">a1</span> <span class="s s-Atom">&lt;=</span> <span class="s s-Atom">a2:</span> <span class="s s-Atom">#</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span> <span class="s s-Atom">位置未检</span> <span class="s s-Atom">mid</span> <span class="o">=</span> <span class="p">(</span><span class="s s-Atom">a1</span><span class="o">+</span><span class="s s-Atom">a2</span><span class="p">)</span><span class="o">//</span><span class="mi">2</span> <span class="s s-Atom">#</span> <span class="s s-Atom">中间索引赋值是关键,可等左,不等右</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="s s-Atom">val</span><span class="p">,</span> <span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="s s-Atom">if</span> <span class="nv">A</span><span class="p">[</span><span class="s s-Atom">mid</span><span class="p">]</span> <span class="o">==</span> <span class="nn">val</span><span class="p">:</span> <span class="s s-Atom">return</span> <span class="s s-Atom">mid</span> <span class="s s-Atom">elif</span> <span class="nv">A</span><span class="p">[</span><span class="s s-Atom">mid</span><span class="p">]</span> <span class="o">&lt;</span> <span class="nn">val</span><span class="p">:</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="s s-Atom">a1</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="o">+</span> <span class="mi">1</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="nn">else</span><span class="p">:</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="o">-</span> <span class="mi">1</span> <span class="nn">else</span><span class="p">:</span> <span class="s s-Atom">return</span> <span class="o">-</span><span class="mi">1</span> <span class="s s-Atom">def</span> <span class="nf">getPosPlus</span><span class="p">(</span><span class="s s-Atom">self</span><span class="p">,</span> <span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="p">,</span> <span class="s s-Atom">val</span><span class="p">,</span> <span class="s s-Atom">searchtype</span><span class="o">=</span><span class="mi">0</span><span class="p">)</span><span class="s s-Atom">:</span> <span class="s s-Atom">&#39;&#39;&#39;支持最左,最右二分查找的修改Plus版本</span> <span class="s s-Atom"> &#39;left&#39;:-1, &#39;fast&#39;:0, &#39;right&#39;:1 其中0是默认版本,找到即返回。</span> <span class="s s-Atom"> &#39;&#39;&#39;</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="o">-</span><span class="mi">1</span> <span class="s s-Atom">while</span> <span class="s s-Atom">a1</span> <span class="o">&lt;</span> <span class="s s-Atom">a2:</span> <span class="s s-Atom">#</span> <span class="s s-Atom">直到重合时,单元素</span> <span class="s s-Atom">mid</span> <span class="o">=</span> <span class="p">(</span><span class="s s-Atom">a1</span><span class="o">+</span><span class="s s-Atom">a2</span><span class="p">)</span><span class="o">//</span><span class="mi">2</span> <span class="s s-Atom">#</span> <span class="s s-Atom">中间索引赋值是关键,可等左,不等右</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="s s-Atom">val</span><span class="p">,</span> <span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="s s-Atom">if</span> <span class="nv">A</span><span class="p">[</span><span class="s s-Atom">mid</span><span class="p">]</span> <span class="o">==</span> <span class="nn">val</span><span class="p">:</span> <span class="s s-Atom">if</span> <span class="s s-Atom">searchtype</span> <span class="o">==</span> <span class="mi">0</span><span class="s s-Atom">:</span> <span class="s s-Atom">return</span> <span class="s s-Atom">mid</span> <span class="s s-Atom">if</span> <span class="s s-Atom">searchtype</span> <span class="o">==</span> <span class="o">-</span><span class="mi">1</span><span class="s s-Atom">:</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="s s-Atom">elif</span> <span class="s s-Atom">searchtype</span> <span class="o">==</span> <span class="mi">1</span><span class="s s-Atom">:</span> <span class="s s-Atom">a1</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="s s-Atom">elif</span> <span class="nv">A</span><span class="p">[</span><span class="s s-Atom">mid</span><span class="p">]</span> <span class="o">&lt;</span> <span class="nn">val</span><span class="p">:</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="s s-Atom">a1</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="s s-Atom">if</span> <span class="s s-Atom">a1</span> <span class="o">+</span> <span class="mi">1</span> <span class="o">==</span> <span class="s s-Atom">a2:</span> <span class="s s-Atom">#</span> <span class="s s-Atom">避免剩余2个元素时,</span> <span class="s s-Atom">mid=左陷入死循环</span> <span class="s s-Atom">a1</span> <span class="o">=</span> <span class="s s-Atom">a2</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">a1</span><span class="p">,</span> <span class="s s-Atom">a2</span><span class="p">,</span> <span class="s s-Atom">mid</span><span class="p">)</span> <span class="nn">else</span><span class="p">:</span> <span class="s s-Atom">a2</span> <span class="o">=</span> <span class="s s-Atom">mid</span> <span class="nn">else</span><span class="p">:</span> <span class="s s-Atom">assert</span> <span class="s s-Atom">a1</span> <span class="o">==</span> <span class="s s-Atom">a2</span> <span class="s s-Atom">return</span> <span class="s s-Atom">a1</span> <span class="s s-Atom">if</span> <span class="nv">A</span><span class="p">[</span><span class="s s-Atom">a1</span><span class="p">]</span> <span class="o">==</span> <span class="s s-Atom">val</span> <span class="s s-Atom">else</span> <span class="o">-</span><span class="mi">1</span> <span class="s s-Atom">if</span> <span class="k">__</span><span class="s s-Atom">name__</span> <span class="o">==</span> <span class="s s-Atom">&#39;__main__&#39;:</span> <span class="s s-Atom">rt</span> <span class="o">=</span> <span class="nv">BinarySearch</span><span class="p">()</span> <span class="s s-Atom">for</span> <span class="nv">A</span> <span class="nf">in</span> <span class="p">((</span><span class="mi">1</span><span class="p">,),</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span><span class="mi">5</span><span class="p">),</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">5</span><span class="p">,</span> <span class="mi">9</span><span class="p">),</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">5</span><span class="p">),</span> <span class="p">[</span><span class="mi">4</span><span class="p">,</span><span class="mi">4</span><span class="p">,</span><span class="mi">10</span><span class="p">,</span><span class="mi">21</span><span class="p">])</span><span class="s s-Atom">:</span> <span class="s s-Atom">n</span> <span class="o">=</span> <span class="nf">len</span><span class="p">(</span><span class="nv">A</span><span class="p">)</span> <span class="s s-Atom">for</span> <span class="s s-Atom">val</span> <span class="s s-Atom">in</span> <span class="nv">A</span><span class="s s-Atom">:</span> <span class="s s-Atom">#</span> <span class="s s-Atom">idx</span> <span class="o">=</span> <span class="s s-Atom">rt</span><span class="p">.</span><span class="nf">getPos</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="p">,</span> <span class="s s-Atom">val</span><span class="p">)</span> <span class="s s-Atom">#</span> <span class="nf">print</span><span class="p">(</span><span class="s s-Atom">&#39;find %3s in %10s: index=%s&#39;</span> <span class="c1">% (val, A, idx))</span> <span class="s s-Atom">#</span> <span class="s s-Atom">支持最左,最右二分查找的修改Plus版本</span> <span class="s s-Atom">idx</span> <span class="o">=</span> <span class="s s-Atom">rt</span><span class="p">.</span><span class="nf">getPosPlus</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="p">,</span> <span class="s s-Atom">val</span><span class="p">)</span> <span class="nf">print</span><span class="p">(</span><span class="s s-Atom">&#39;find %3s in %10s: index=%s&#39;</span> <span class="c1">% (val, A, idx))</span> <span class="s s-Atom">idx</span> <span class="o">=</span> <span class="s s-Atom">rt</span><span class="p">.</span><span class="nf">getPosPlus</span><span class="p">(</span><span class="nv">A</span><span class="p">,</span> <span class="s s-Atom">n</span><span class="p">,</span> <span class="s s-Atom">val</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">)</span> <span class="nf">print</span><span class="p">(</span><span class="s s-Atom">&#39;find %3s in %10s: index=%s&#39;</span> <span class="c1">% (val, A, idx))</span> </pre></div> <h3 id="k">寻找斜率为K的点对<a class="headerlink" href="#k" title="Permanent link">&para;</a></h3> <p>算法题:</p> <p>有一个数组,数组每个元素是一个对象,每个对象有x和y两个值,这个数组记录 为A: A = [{x1, y1}, {x2, y2}, &hellip;];我们把数组A中任意两个满足以下关系的元素叫 做“点对”:(y2-y1)/(x2-x1) = K, K是一个常数。编写程序:给定A与K,返回A中点&nbsp;对的数目。</p> <div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">itertools</span> <span class="kn">import</span> <span class="n">groupby</span> <span class="n">K</span> <span class="o">=</span> <span class="mi">1</span> <span class="c1"># 斜率</span> <span class="k">def</span> <span class="nf">kpairs</span><span class="p">(</span><span class="n">A</span><span class="p">,</span> <span class="n">k</span><span class="o">=</span><span class="n">K</span><span class="p">):</span> <span class="sd">&#39;&#39;&#39;</span> <span class="sd"> 分析:计算一遍点到直线y=kx距离 |Kx - y| / √(k*k+1),距离等两点的可能与y=kx平行。先验证y=kx上的,距离等不一定平行。</span> <span class="sd"> 技巧:结合题目实际,可不开平方pow运算,不取绝对值。</span> <span class="sd"> &#39;&#39;&#39;</span> <span class="k">print</span><span class="p">(</span><span class="s1">&#39;debug: kpairs(</span><span class="si">%s</span><span class="s1">, </span><span class="si">%s</span><span class="s1">)&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">k</span><span class="p">,</span> <span class="n">A</span><span class="p">))</span> <span class="n">result</span> <span class="o">=</span> <span class="mi">0</span> <span class="n">distance</span> <span class="o">=</span> <span class="p">[</span> <span class="p">(</span><span class="n">k</span><span class="o">*</span><span class="n">x</span><span class="o">-</span><span class="n">y</span><span class="p">)</span> <span class="o">/</span> <span class="p">(</span><span class="n">k</span><span class="o">**</span><span class="mi">2</span><span class="o">+</span><span class="mi">1</span><span class="p">)</span> <span class="k">for</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">y</span><span class="p">)</span> <span class="ow">in</span> <span class="n">A</span> <span class="p">]</span> <span class="n">point_distance</span> <span class="o">=</span> <span class="nb">sorted</span><span class="p">(</span><span class="nb">zip</span><span class="p">(</span><span class="n">A</span><span class="p">,</span> <span class="n">distance</span><span class="p">),</span> <span class="n">key</span><span class="o">=</span><span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">x</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> <span class="c1"># 距离排序,取点</span> <span class="k">for</span> <span class="n">distance</span><span class="p">,</span> <span class="n">pointiter</span> <span class="ow">in</span> <span class="n">groupby</span><span class="p">(</span><span class="n">point_distance</span><span class="p">,</span> <span class="n">key</span><span class="o">=</span><span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">x</span><span class="p">[</span><span class="mi">1</span><span class="p">]):</span> <span class="n">points</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">x</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">pointiter</span><span class="p">)</span> <span class="n">count</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">points</span><span class="p">)</span> <span class="k">print</span><span class="p">(</span><span class="s1">&#39;debug: line:y=</span><span class="si">%3s</span><span class="s1">x, got </span><span class="si">%3s</span><span class="s1"> point distance=</span><span class="si">%7.3s</span><span class="s1">: </span><span class="si">%s</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">k</span><span class="p">,</span> <span class="n">count</span><span class="p">,</span> <span class="n">distance</span><span class="p">,</span> <span class="n">points</span><span class="p">))</span> <span class="c1"># debug</span> <span class="k">if</span> <span class="n">count</span> <span class="o">&gt;</span> <span class="mi">1</span><span class="p">:</span> <span class="n">result</span> <span class="o">+=</span> <span class="n">count</span><span class="o">*</span><span class="p">(</span><span class="n">count</span><span class="o">-</span><span class="mi">1</span><span class="p">)</span><span class="o">/</span><span class="mi">2</span> <span class="c1"># 组合数 4 -&gt; 6</span> <span class="k">return</span> <span class="n">result</span> <span class="k">if</span> <span class="vm">__name__</span> <span class="o">==</span> <span class="s1">&#39;__main__&#39;</span><span class="p">:</span> <span class="n">A</span> <span class="o">=</span> <span class="p">[(</span><span class="mi">0</span><span class="p">,</span><span class="mi">3</span><span class="p">),</span> <span class="p">(</span><span class="mi">3</span><span class="p">,</span><span class="mi">0</span><span class="p">),</span> <span class="p">(</span><span class="mi">3</span><span class="p">,</span><span class="mi">3</span><span class="p">),</span> <span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">0</span><span class="p">)]</span> <span class="c1"># 正方形</span> <span class="k">assert</span> <span class="n">kpairs</span><span class="p">(</span><span class="n">A</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">,</span> <span class="s1">&#39;check and debug kpairs(</span><span class="si">%s</span><span class="s1">)&#39;</span><span class="o">%</span><span class="n">A</span> <span class="k">assert</span> <span class="n">kpairs</span><span class="p">(</span><span class="n">A</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span> <span class="o">==</span> <span class="mi">0</span><span class="p">,</span> <span class="s1">&#39;check and debug kpairs(</span><span class="si">%s</span><span class="s1">)&#39;</span><span class="o">%</span><span class="n">A</span> <span class="n">A</span> <span class="o">=</span> <span class="p">[(</span><span class="mi">3</span><span class="p">,</span><span class="mi">9</span><span class="p">),</span> <span class="p">(</span><span class="mi">9</span><span class="p">,</span><span class="mi">9</span><span class="p">),</span> <span class="p">(</span><span class="mi">20</span><span class="p">,</span><span class="mi">20</span><span class="p">),</span> <span class="p">(</span><span class="mi">10</span><span class="p">,</span><span class="mi">16</span><span class="p">),</span> <span class="p">(</span><span class="mi">22</span><span class="p">,</span><span class="mi">28</span><span class="p">)]</span> <span class="k">assert</span> <span class="n">kpairs</span><span class="p">(</span><span class="n">A</span><span class="p">)</span> <span class="o">==</span> <span class="mi">4</span><span class="p">,</span> <span class="s1">&#39;check and debug kpairs(</span><span class="si">%s</span><span class="s1">)&#39;</span><span class="o">%</span><span class="n">A</span> <span class="k">assert</span> <span class="n">kpairs</span><span class="p">(</span><span class="n">A</span><span class="p">,</span> <span class="mi">4</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">,</span> <span class="s1">&#39;check and debug kpairs(</span><span class="si">%s</span><span class="s1">)&#39;</span><span class="o">%</span><span class="n">A</span> </pre></div> <h2 id="_2">参考<a class="headerlink" href="#_2" title="Permanent link">&para;</a></h2> <ol> <li>点到直线距离公式的几种推导 <a href="https://zhuanlan.zhihu.com/p/26307123">https://zhuanlan.zhihu.com/p/26307123</a></li> </ol>腾讯2014实习面经——记一个非计算机学生的首次面试2014-04-30T23:58:00+08:002014-04-30T23:58:00+08:00pythonwoodtag:blog.pythonwood.com,2014-04-30:/2014/04/腾讯2014实习面经——记一个非计算机学生的首次面试/<p>地点:华南理工大学大学城校区,为广州考点。</p> <p>流程:网申3.X + 笔试4.12 + 一面4.15 + 二面4.17 + 三面4.19 +&nbsp;签约4.25</p> <h3 id="_1">前言<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3> <p>腾讯实习招聘笔试到拿到offer(软件工程师-研发反向),历时两星期 …</p><p>地点:华南理工大学大学城校区,为广州考点。</p> <p>流程:网申3.X + 笔试4.12 + 一面4.15 + 二面4.17 + 三面4.19 +&nbsp;签约4.25</p> <h3 id="_1">前言<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3> <p>腾讯实习招聘笔试到拿到offer(软件工程师-研发反向),历时两星期,只算笔试到终面的话则是一星期,效率比阿里要好。</p> <p>腾讯是我的处面,一路过来我没有夸张,只是平实的叙述我的故事,认真谨慎的答问。</p> <p>我容易紧张,但幸好没有太紧张。</p> <h3 id="2014-3-18">2014-3-18 网申(宣讲会在大学城太远了跳过~呵呵)<a class="headerlink" href="#2014-3-18" title="Permanent link">&para;</a></h3> <p>(^0^)</p> <p>准备:</p> <p>1、寒假就开始准备,主要是重拾算法,发现没之前开始学编程那么难了。</p> <p>2、寒假期间pythontip有个挑战python,做72题后排第三名。挑战最长回文,最长上升子串等算法题,综合能力提升。</p> <p>3、看完《编程珠玑》和《编程之美》。</p> <p>4、google面经,做往年题练手。</p> <p>5、Linux下gcc+vim实践7大经典排序算法(这个效用较高)。</p> <p>6、精心准备的简历,3月8号就做了1.0版,后修改不下10次,要求尽量简洁美观。</p> <h3 id="2014-4-12-1430-1600">2014-4-12 周六 14:30 - 16:00 笔试<a class="headerlink" href="#2014-4-12-1430-1600" title="Permanent link">&para;</a></h3> <p>×—×</p> <p>心情:</p> <p>1、收到信息,知道阿里笔试被鄙视了。</p> <p>2、三个项目在手(都是不感冒的web项目-_-)。</p> <p>3、报大创,课程作业,等等等等……,一个字,累!</p> <p>内容:</p> <p>1、20不定选择(一半把握)填空5题(4题把握)附加2题(会后一题)。</p> <p>2、C语言C++,操作系统,网络,数据库,经典算法,数学<span class="caps">IQ</span>题加起来占80%以上吧。</p> <p>感受:</p> <p>做的不上不下,做得快,但修改得多。交卷到了,还把一题对的改错了,囧。</p> <p>后记:</p> <p>1、打击过后的我只敢保守地估计,谨慎地乐观,默默地独自回校。</p> <p>2、心中感觉一些轻松,一些冷漠,像我本是局外人。</p> <h3 id="2014-4-15-1000-1100">2014-4-15 周二 10:00 - 11:00 一面 单面<a class="headerlink" href="#2014-4-15-1000-1100" title="Permanent link">&para;</a></h3> <p>T_T</p> <p>过程:</p> <p>1、面试官是位大叔,讲话少,自我介绍时“嗯”了很多,有时闭着眼在听。</p> <p>2、以C语言的宏的作用是什么开头,问了我很多广泛问题。</p> <p>3、幸好C语言,C++我都记得,答取结构偏移址,宏用途,宏在C与C++之间重要性的区别还答得上。</p> <p>4、但是问到数据库时瘪了,索引什么的更是一知半解(本来至少应该摆个二分法),大数据找重也不好的。最记得让我描述http协议,我不知从何说起,各点都提一提。</p> <p>5、我尝试过避开这些,引导到Linux上,无效。越到后面我就越觉得机会小。</p> <p>6、最后让我一边去写strcpy,我用了assert,并加上测试,还应此知道缺const。</p> <p>感受:</p> <p>1、没玩过游戏,但我觉得一个初出茅庐的0级玩家被40级玩家虐的时候也是这样吧。</p> <p>2、我知道简单问题考细节,幸好这时刻这点我做得不错。</p> <p>3、从专业名看到话面试官还是以为我技术出身,幸好后来我答题时明确说明了。</p> <p>4、答题是不坚定,没自信,这是我的弱点。</p> <p>后记:</p> <p>1、阿里铩羽而归后的又一次打击,本来觉得我应该无后文,继续华为,小米,百度实习关注填表。</p> <p>2、我后来惊喜收到二面短信,可能和我很重实践,Linux,github,操作系统代码有关。</p> <p>3、当时答得不太好的如socket,进程通信,netstat&nbsp;-ptln我都马上复习了,为了别的面试。结果让我在二面表现更好。</p> <h3 id="2014-4-17-830-900">2014-4-17 周四 8:30 - 9:00 二面 单面<a class="headerlink" href="#2014-4-17-830-900" title="Permanent link">&para;</a></h3> <p><em>^-^</em></p> <p>过程:</p> <p>1、自我介绍8分钟,以Ubuntu14.04正式版发布这开源新闻开始,还是那篇讲学习经历和项目的自我介绍。最浓缩就是:windows-&gt;Linux-&gt;Python。期间他有打断问我具体细节,我都详细作答了。</p> <p>2、他问我有没有纸,我说8太早了工作人员让我直接去房间。面试官有些失望的样子,我在暗想,草稿纸算法题目必需的,这是对我故意的眷顾,会不会是上个面试官的特意安排吗?不知道,也许就是偶然的幸运。</p> <p>3、面试问题问细节比较多,问的深度和一面挺像,所以感觉没什么压力。</p> <p>4、面试官过程中礼貌而中肯地多次说&rdquo;<span class="caps">OK</span>&rdquo;,最后说“<span class="caps">OK</span>,现在你有几分钟时间问我问题。”。</p> <p>5、我问了腾讯与开源的一个烟雾弹问题,还问微信未来是否会像易迅一样开微店,——干脆利三个字“有可能”——意料之中,然后我们最后握手告别。</p> <p>感受:</p> <p>1、一开始面试官就看出我的紧张,他笑着指出了。还好之后整个过程都比较轻松。</p> <p>3、能到这里其实我是满足的,不管怎样。</p> <p>4、我在最后的一瞬间感觉到了一种肯定,那握手和神情。但我依然很保守地乐观。</p> <p>后记:</p> <p>1、出来后心情,做番201去星海过程中观赏者大学城。</p> <p>2、回去过程在回想面试,面试官给我感觉挺好的,他当时穿了米黄色衬衫,中等身高有点胖,印象中头发有点蓬松,和脸相搭。</p> <p>3、出来后直到回学校,觉得我是幸运的。</p> <h3 id="2014-04-19-1522-1537">2014-04-19 周六 15:22 - 15:37 三面 单面<a class="headerlink" href="#2014-04-19-1522-1537" title="Permanent link">&para;</a></h3> <p>(^w^)</p> <p>感受:</p> <p>1、微信状态变成<span class="caps">HR</span>面是很开心,因为有<span class="caps">HR</span>不怎么刷技术岗之说。同时感概些许,也许就在前面了,但我告诫自己绝不能倒在这关。</p> <p>2、告诉舍友我到<span class="caps">HR</span>时,他们都为我高兴了,我们笔试时几乎全宿舍都去了(光说动员,6人中5人去了-_-)。</p> <p>3、紧张而兴奋,期待而舒畅的等待着。</p> <p>过程:</p> <p>1、面试官还是男性,还是那份简历,还是华工大学城中心酒店。</p> <p>2、15分钟,自我介绍,和<span class="caps">HR</span>聊天,我不太健谈,不过还算一个愉快的过程。</p> <p>3、最后让问问题,查笔试成绩没成,问可能去向问到了。</p> <p>后记:</p> <p>2014-04-25,offer终签成,一件好事来了。哈哈。</p> <h1 id="_2">面试经历总记:<a class="headerlink" href="#_2" title="Permanent link">&para;</a></h1> <p>我是个粗心人!</p> <p>1、14号晚收到一面通知在15好,而我以为当天是13号,睡前发现这个“<span class="caps">BUG</span>”,起来准备到2点才睡,第二天7点起床。</p> <p>2、微信查进度jg这两字符总漏了,“修复”后得到第一个回复是处在到<span class="caps">HR</span>面中。我的色弱也许占部分原因。</p> <p>3、我是个不懂得察言观色,后知后觉型小傻呆。所以无法把握自己的面试,最近有看《Lie To&nbsp;Me》,对没能运用这知识有点遗憾。</p> <p>我是个认真务实好学的人!</p> <p>1、自学C/C++,java,html/css/js,kenerl,Linux,Shell,Python等等。</p> <p>2、为应聘做了很多的准备,寒假就开始,有针对性的练习算法,多次锤炼简历,2小时准备的自我介绍586字。</p> <p>3、不懂时就问,敢问,问得很多,感觉有时被鄙视了(我想懂得范畴以外,我都是白痴)。</p> <p>4、边学边实践,边看书籍,边写敲键盘。因此记得还算牢固,学习速度还可以。</p> <p>5、不是到用的时候才有,而是到用的时候来总结。所以不会被问到哑口无言。</p> <p>经验总结</p> <p>后来我猜,自学能力,多种语言,C/C++功底,Linux,blog,github,项目,这些是决定我能留下来的组成部分。</p> <h3 id="_3">其他:<a class="headerlink" href="#_3" title="Permanent link">&para;</a></h3> <p>我是谁?&nbsp;我是大学开始自学技术的商科学生</p> <p>1、技术的我:一个Linux与Python爱好者,关注开源和C/C++,使用Vim编辑器,喜欢Shell下工作。(技术宅?不是的,希望像耗子大叔一样。)</p> <p>2、学生的我:一个商科11届大学生,来自广东文科老二,理科老三的(按高考分数线的话)211暨南大学(<span class="caps">JNU</span>)。大学以自学副业为主,暂没获得过奖学金。</p> <p>3、生活的我:爱好比较广泛(童心<span class="caps">OR</span>好奇心……随便吧-_-);历史(春秋迷),登山(户外迷),排球还不错,听电台,LoveQ。听电台的90后不多了,我就是其中之一,嘻!</p> <p>关于</p> <p>关于简历。word是彩版,但印的是黑白,怕面试官认为华而不实。(-_-,也许心疼成本才是真,囧)。</p> <p>关于招聘。搜“算法+数据结构”可能还不如你搜“笔试面经”获得的结果好,强,全。</p> <p>关于经验。腾讯2013暑期实习生招聘经历分享对我很有帮助,作者是同校同乡的上一届师兄。这后来成为我写本文的原因一部分。</p> <p>关于暨大。个人认为腾讯与暨大之间存在信息不对称问题,结果导致暨大实习生比例过低。前几年均如此。当然也不排除暨大自身问题啦。</p> <p>关于腾讯。我明白获得实习offer只是开始,但是腾讯给出的资薪待遇挺不错的,至少对于我,呵呵。</p> <p>关于自学。图书馆 -&gt; google -&gt; 独立博客 -&gt; rss鲜果 -&gt;&nbsp;开源。遇见Linux是转哲点。</p> <p>我用到过的好资源共享:</p> <p>别的程序员是怎么读你的简历的&nbsp;http://coolshell.cn/articles/1695.html</p> <p>找工作笔试面试那些事儿(系列)&nbsp;http://blog.csdn.net/han_xiaoyang/article/category/1664765</p> <p>白话经典算法&nbsp;http://blog.csdn.net/morewindows/article/details/17488865</p> <p>程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦&nbsp;http://blog.csdn.net/v_july_v/article/details/6543438</p> <p>2014年计算机求职总结&ndash;准备篇&nbsp;http://blog.csdn.net/luckyxiaoqiang/article/details/13000431</p> <p>《程序员编程艺术 — 面试和算法心得》&nbsp;https://github.com/julycoding/The-Art-Of-Programming-By-July</p> <p>《剑指Offer——名企面试官精讲典型编程题》博客&nbsp;http://zhedahht.blog.163.com/</p>