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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 你用对锁了吗?浅谈 Java “锁” 事

    你用对锁了吗?浅谈 Java “锁” 事

    2020年11月20日
  • navicat激活码2021【2021最新】

    (navicat激活码2021)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.cn/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~DB…

  • Floyd算法详解——包括解题步骤与编程[通俗易懂]

    Floyd算法详解——包括解题步骤与编程[通俗易懂]一、Floyd算法原理Floyd算法是一个经典的动态规划算法,它又被称为插点法。该算法名称以创始人之一、1978年图灵奖获得者、斯坦福大学计算机科学系教授罗伯特·弗洛伊德命名。Floyd算法是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法,算法目标是寻找从点i到点j的最短路径。从任意节点i到任意节点j的最短路径不外乎2种可能,1是直接从i到j,2是从i经过若干个节点k到j…

  • bootstrap的使用方法「建议收藏」

    bootstrap的使用方法「建议收藏」bootstrap的简单使用1.通过npm下载bootstrap2.进入官网的全局css样式3.选择一个样式实验一下1.通过npm下载bootstrap进入项目文件夹下的命令行输入以下命令npminit-ynpmbootstrap@3引用的方法不尽相同,也可以用别的方法进行引入可参考https://v3.bootcss.com/getting-started/#download2.进入官网的全局css样式链接在这:https://v3.bootcss.com/css/#form

  • 【Matlab】如何规范地编写一个MATLAB函数文件

    【Matlab】如何规范地编写一个MATLAB函数文件在matlab中,M文件分为脚本文件和函数文件。如果M文件的第一个可执行语句以function开头,那这个M文件就是函数文件。函数文件内定义的变量为局部变量,只在函数文件内部起作用,当函数文件执行完后,这些内部变量将被清除。本文介绍如何规范地编写一个函数文件。通常,函数文件由函数声明行、H1行、在线帮助文本区、编写和修改记录、函数主体等几个部分组成。格式如下:function输出形参…

  • pycharm安装教程中文_java将对象转为json

    pycharm安装教程中文_java将对象转为json#1.下载安装包下载地址(http://www.jetbrains.com/pycharm/download/#section=windows)#2.安装#3.激活选择Activationcode在http://idea.lanyus.com/获取注册码修改hosts文件,加入以下字段0.0.0.0account.jetbrains.com#4.中文界面下载语言包https://github…

发表回复

您的电子邮箱地址不会被公开。

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