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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值