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

在单链表的第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.提供两个版本号的编号定位节点的函数或者匹配定位节点的函数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115243.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Ubuntu彻底卸载jdk「建议收藏」

    Ubuntu彻底卸载jdk「建议收藏」参考链接原链接1、移除所有java相关的包(sun,Oracle,openJDK,lcedTeaplugins,GIJ)#apt-getupdate#apt-cachesearchjava|awk'{print($1)}’|grep-E-e’^(ia32-)?(sun|oracle)-java’-e’^openjdk-‘-e’^icedtea’-e’^(default|gcj)-j(re|dk)’-e’^gcj-(.*)-j(re|dk)’-e’

    2022年6月25日
    36
  • Android BLE蓝牙4.0开发详解

    Android BLE蓝牙4.0开发详解这篇博客主要讲解蓝牙 BLE 的用法 在讲解之前先讲一些概念性的东西 对于之前没接触过蓝牙开发 现在手上又有个蓝牙 BLE 项目需要做的人 先看下这些概念还是很重要的 因为我之前就是这样 之前没有接触过蓝牙方面的开发 然后来了个蓝牙的项目 于是就到网上百度了一番 于是有点茫然 产生了几点疑惑 1 发现蓝牙有传统蓝牙和低功耗蓝牙 ble 之分 那么什么是传

    2025年9月28日
    3
  • candump命令_生成dump文件命令

    candump命令_生成dump文件命令hexdump以ASCII、十进制、十六进制或八进制显示文件内容。

    2022年9月21日
    3
  • MATLAB中画折线图:plot函数的简单用法

    MATLAB中画折线图:plot函数的简单用法使用plot绘制二维图像MATLAB中plot函数常常被用于绘制各种二维图像,其用法也是多种多样,本文仅介绍plot函数的基本用法——使用plot函数绘制二维点图和线图。plot函数的一般调用形式如下:plot(X,Y,LineSpec)其中X由所有输入点坐标的x值组成,Y是由与X中包含的x对应的y所组成的向量。LineSpec是用户指定的绘图样式,主要选项如下:Specif…

    2022年6月9日
    40
  • 运维必须掌握的27道Linux面试题

    运维必须掌握的27道Linux面试题1.解释下什么是GPL,GNU,自由软件?GPL:(通用公共许可证):一种授权,任何人有权取得、修改、重新发布自由软件的权力。GNU:(革奴计划):目标是创建一套完全自由、开放的的操作系统。自由软件:是一种可以不受限制地自由使用、复制、研究、修改和分发的软件。主要许可证有GPL和BSD许可证两种。 2.如何选择Linux操作系统版本?一般来讲,桌面用

    2022年5月13日
    69
  • SQL SELECT TOP 子句详解

    SQL SELECT TOP 子句详解SQLSELECTTOP子句SELECTTOP子句用于规定要返回的记录的数目。语法如下SELECTTOPnumber|percentcolumn_name(s)FROMtable_name;实例:从MyTables表里选取前两行数据实例2从MyTables表里取前百分之十的数据需要注意的是如下图那是我整张MyTables表的数据,可以看出根本没有十条数据,那那…

    2022年7月13日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号