• 在单链表的第i个位置后插入一个节点(阿里+腾讯等面试题总结)


    时间:2014.04.26

    地点:基地

    —————————————————————————

    一、题目

      题目是非常easy和基础,就是在单链表的第i个位置后插入一个节点。要求写代码,5分钟之内完毕。面腾讯和阿里的同学都有面到,于是总结几个技巧。这样的限时写代码往往一紧张尽管特基础但稍加不注意也非常容易出错。

    —————————————————————————

    二、分析

      1.先依照一般的步骤,我们要得到第链表第i个位置的指针。

      2.然后再在刚刚得到的指针之后插入新节点

    Node* ListLocate(Node* head_ptr,size_t position)
    {
    	Node* curosr=nullptr;
    	for(size_t i=1;(i<position)&&(cursor!=nullptr);++i)
    		cursor=cursor->get_link();
    	return cursor;
    }	
    const Node* ListLocate(const Node* head_ptr,size_t position)
    {
    	const Node* curosr=nullptr;
    	for(size_t i=1;(i<position)&&(cursor!=nullptr);++i)
    		cursor=cursor->get_link();
    	return cursor;
    }
    void ListInsert(Node* previous_ptr;const Node::value_type& entry)
    {	
    	Node* insert_ptr=new Node(entry,previous_ptr->get_link());
    	previous_ptr=insert_ptr;
    }

    —————————————————————————

    三、总结

      这里获得第i个位置的指针写了两个版本号,即为提供通用性,当然这里对于题目要求的是多余的,由于题目要求是肯定要通过指针改动链表。个人比較喜欢固定一种模式,即经常使用的代码编写模式,假设算法实现原理是一样的,仅仅是在代码的表现上有所差别,我认为就不是必需花心思耍花样。今天用cursor遍历链表,明天用list_ptr遍历链表,往后也不easy出错。

    在链表的实现中比方还可提炼几种编码规范:

    1.使用cursor遍历链表指针

    for(Node* head_ptr;cursor!=nullptr;cursor=curosr->get_link())
    {
        .......
    }

    2.提供两个版本号的编号定位节点的函数或者匹配定位节点的函数

  • 相关阅读:
    jmm八大原子操作
    线程状态及各状态下与锁和CPU的关系
    navicat破解
    解析JSON完美案例
    Caused by: java.security.cert.CertificateException: No subject alternative names matching IP address xxx.xx.xx.xx found
    linux修改hosts并立即生效设置
    winows下常用ng命令
    MySql 事务隔离级别简述,以及为什么互联网项目用:读已提交(Read Commited)这个隔离级别
    vite vue webstorm修改代码页面不自动更新
    MySQL 8的递归查询
  • 原文地址:https://www.cnblogs.com/yxwkf/p/5417867.html
Copyright © 2020-2023  润新知