在单链表的第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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 8个高质量图标的最佳搜索引擎

    8个高质量图标的最佳搜索引擎

    对于每个网站开发者来说,设计是很重要的一部分。图标是设计中一个环节。你可以找到许多集合图标的网站。但很难找到免费的高质量图标。这是我在此分享一些免费的高质量图标搜索引擎的原因。你要访问这些引擎以找到高质量图标。如果你知道更多的网站,也请与我们分享!
    IconFinder
    以简便并且有效的方式为网站设计者和开发人员提供高质量的图标。

    Iconlet
    是一个单纯的免费图标和图像的搜索引擎。

    IconScan

    2022年5月23日
    58
  • Idea激活码最新教程2023.3.5版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2023.3.5版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2023 3 5 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2023 3 5 成功激活

    2025年5月27日
    6
  • android四种启动模式_android:windowSoftInputMode

    android四种启动模式_android:windowSoftInputMode(1)添加头文件:#include(2)在特定驱动结构体中添加early_suspend结构:#ifdefCONFIG_HAS_EARLYSUSPENDstructearly_suspendearly_suspend;#endif(3)在驱动probe函数中注册相关early_suspend结构体:#ifdefCONFIG_HAS_EARLYSUSPEND

    2022年9月18日
    2
  • Linux下的文件IO编程[通俗易懂]

    Linux下的文件IO编程[通俗易懂]Linux中处处皆文件,可以通过终端命令来对文件进行操作,也可以通过编程语言(程序)来对文件进行操作。而在C语言中可以通过标准IO和文件IO对文件进行操作,上一篇文章描述了标准IO,这篇文章当然是关于文件IO的基本操作,同时给予了详细的例程和标准IO进行对比。

    2022年4月30日
    53
  • python安装教程[通俗易懂]

    python安装教程[通俗易懂]python安装教程本章节我们将向大家介绍如何在本地搭建Python开发环境。Python可应用于多平台包括Linux和MacOSX。你可以通过终端窗口输入"python&

    2022年7月5日
    25
  • Java实现AES加密与解密(秘钥)

    Java实现AES加密与解密(秘钥)

    2021年4月9日
    153

发表回复

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

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