在单链表的第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)
上一篇 2022年2月7日 上午7:00
下一篇 2022年2月7日 上午8:00


相关推荐

  • linux shell脚本编写实例_常用的shell脚本

    linux shell脚本编写实例_常用的shell脚本LINUXShell脚本编程实例详解(一)上ping命令测试网段内主机的2例详解使用linux已经有10来年了但是一直止于各种服务器的搭建和环境的调优,能力不能得到提升,今天突然下定决心学习Shell脚本编程,因此以网上广为流传的《Shell脚本100例》为基础学习、实验和笔记。废话不说上栗子。使用vimshell100-scanip-1.sh命令创建脚本文件#!/bin…

    2022年10月3日
    4
  • Membership 二

    Membership 二MembershipPr 提供了 Membership 数据源和服务之间的所有接口 在 Asp net2 0 中提供了两个 Provider SqlMembershi 和 ActiveDirect 从命名中我们也可以看出 SqlMembershi 是把 sqlserver 和 sqlserverexp 数据库作为数

    2026年3月17日
    3
  • 有组织纠缠之OpenClaw一个奥地利的间谍智能体

    有组织纠缠之OpenClaw一个奥地利的间谍智能体

    2026年3月14日
    2
  • 非零矩阵A可以写成某个列满秩矩阵与某个行满秩矩阵的乘积

    非零矩阵A可以写成某个列满秩矩阵与某个行满秩矩阵的乘积非零矩阵 A 可以写成某个列满秩矩阵与某个行满秩矩阵的乘积引理 设 AAA 是 m rm timesrm r 矩阵 则 AAA 是列满秩的充要条件为存在 m mm timesmm m 可逆矩阵 PPP 使 A P ErO A P begin pmatrix E r O end pmatrix A P Er O 同样地 AAA 为行满秩的充要条件为存在 r rr timesrr r 的可逆矩阵 Q 使 A Q EmO A Q begin pmatrix E m amp O end pmatr

    2026年3月16日
    2
  • awg线径与电流_AWG线径电流对照表

    awg线径与电流_AWG线径电流对照表该楼层疑似违规已被系统折叠隐藏此楼查看此楼 AWG 线径电流对照表截面积电阻值正常电流最大电流公制 mm 英制 inch mm2 W km A A 4 011 680 46107 220 17423 5663 010 40 010 21335 6142 09 270 430 26266 4951 08 250 490

    2026年3月20日
    2
  • JAVA中字符串和数组做参数传递的情况

    JAVA中字符串和数组做参数传递的情况首先明确的一点就是在java中只有值传递!只有值传递!理论依据来自《thinkinjava》。接下来就是具体说明为何java只有值传递。因为java中有基本类型和引用类型两种数据类型,再加上String这个特殊的类型,所以主要从三个方面就行解释。1.基本数据类型先看代码publicclassDemo01{publicvoidchange(inta){System.out.println(“副本a的初始…

    2022年5月6日
    86

发表回复

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

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