博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
判断数组链表环相关算法
阅读量:4112 次
发布时间:2019-05-25

本文共 484 字,大约阅读时间需要 1 分钟。

一般需求如下:

1.判断某链表中是否有环(某年研究生入学统招试题)?

2.判断某int[]是否有环,举例如下根据其值 array[i]=0时原地不走,相当于有环了;array[i]=-10,向后移动10步;array[i]=10向前走10步。当某停止点两次停止过那么算有环

 

分析:

在有足够空间的前提下都容易实现,在没有额外空间的前提下(变量不算),那么就需要思考了,题目2如果不是int而是一个object那么很容易,对object进行封装两个属性来标记是否访问过,同时题目1也适用,我们可以对访问过的节点设置某值来区分是否访问过,也可以通过步长不等的指针遍历,当指针重合的时候代表有环,其实这两个题都适用。

 

思路1:

题目1和2均使用:

定义两个指针p1和p2,p1每次走1个单元,p2每次走2个单元(题目2的两次停顿);

当p1和p2重叠就代表有环,反之无环;

 

思路2:

定义一个指针,找一个固定值并且能区分其他节点值,当访问过了就设置标记位,来标记是否访问过,题目1看具体的需求,科目2设置成0;

遍历设置标记位,当要遍历的值跟设置的值相同那么有环,反之无环;

 

转载地址:http://nnqsi.baihongyu.com/

你可能感兴趣的文章
c++写时拷贝1
查看>>
Linux网络编程---I/O复用模型之poll
查看>>
Java NIO详解
查看>>
在JS中 onclick="save();return false;"return false是
查看>>
idea 有时提示找不到类或者符号
查看>>
matplotlib.pyplot.plot()参数详解
查看>>
MFC矩阵运算
查看>>
ubuntu 安装mysql
查看>>
c# 计算器
查看>>
C# 简单的矩阵运算
查看>>
gcc 常用选项详解
查看>>
c++输出文件流ofstream用法详解
查看>>
firewalld的基本使用
查看>>
Linux下SVN客户端使用教程
查看>>
Linux分区方案
查看>>
nc 命令详解
查看>>
如何使用 systemd 中的定时器
查看>>
git命令速查表
查看>>
linux进程监控和自动重启的简单实现
查看>>
OpenFeign学习(三):OpenFeign配置生成代理对象
查看>>