双循环链表的java实现——《算法》读书笔记

本贴最后更新于 3036 天前,其中的信息可能已经时移世异

####这是一个双链表环,从头插入元素,可以实现从任意地方删除元素,测试是约瑟夫问题。

添加元素的时间复杂度为 O(1),删除元素的时间复杂度为 O(1).由于约瑟夫问题是在不停的删除元素,现在假设有 n 个元素,每 hop 个元素自杀一次。总共删除 n-1 次,每删除一次走 hop 步。所以约瑟夫问题的时间复杂度为 O(hop*(n-1))=O(n*hop)。

import java.util.Iterator;

/**
 * Created by dog on 3/25/16.
 * 这是一个双链表环,从头插入元素,可以实现从任意地方删除元素
 */
public class CircularDoubleLinked<Item> implements Iterable<Item>{

	private Node head;
	private Node tail;
	private int N;

	public CircularDoubleLinked(){
		head = new Node();
		tail = new Node();

	}

	private class Node{
		Item item;
		Node left;
		Node right;
	}

	public int size(){
		return N;
	}

	public boolean isEmpty(){
		return size()==0;
	}

	public void push(Item item){
		if(isEmpty()){
			Node newFirst = new Node();
			newFirst.item=item;

			head.right = newFirst;
			tail.left=newFirst;

		}else {

			Node newFirst = new Node();
			newFirst.item=item;
			newFirst.right = head.right;
			head.right.left=newFirst;
			newFirst.left = tail.left;
			tail.left.right=newFirst;
			head.right=newFirst;

		}
		N++;
	}

	public Item remove(Node node){

		if(node!=null) {
			Item item = node.item;
			if (node == head.right) {
				Node last = node.left;
				Node next = node.right;
				last.right = next;
				next.left = last;

				head.right = node.right;

				node.right = null;
				node.left = null;
				node = null;
			} else if (node == tail.left) {
				Node last = node.left;
				Node next = node.right;
				last.right = next;
				next.left = last;

				tail.left = node.left;

				node.right = null;
				node.left = null;
				node = null;
			} else {
				Node last = node.left;
				Node next = node.right;
				last.right = next;
				next.left = last;
				node.right = null;
				node.left = null;
				node = null;
			}
			N--;
			return item;
		}else {
			return null;
		}

	}
	@Override
	public ListIterator iterator() {
		return new ListIterator();
	}


	private class ListIterator implements Iterator<Item>{

		Node current = head.right;
		Node follow = head;
		@Override
		public boolean hasNext() {
			if(current!=null && size()>0){
				return true;
			}else {
				return false;
			}

		}

		@Override
		public Item next() {
			Item item = current.item;
			//System.out.println("current:地址"+current);
			follow=current;
			current=current.right;
			return item;
		}

		@Override
		public void remove() {
			Node temp = follow.right ;
			System.out.println(CircularDoubleLinked.this.remove(follow));
			follow = temp;
		}
	}

	public static void main(String[]args){


		//丢手绢问题的实现
		//test
		//每hop个人报数一次
		int N = 41;
		int hop = 3;

		CircularDoubleLinked d = new CircularDoubleLinked<Integer>();

		//添加元素
		for(int i=N;i>0;i--) d.push(i);

		//开始游戏
		int k=1;
		for(Iterator i = d.iterator() ;d.size()>1;) {
			i.next();
			if(k%(hop+1)==hop){
				i.remove();
				k=0;
			}
			k++;
		}

		System.out.println("剩下:"+d.head.right.item);

	}
}
  • 约瑟夫问题
    1 引用 • 4 回帖
  • 链表
    12 引用 • 6 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3169 引用 • 8208 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250

    @ss 昨天我看到了两个标题好像是一样的,就被我删除了,抱歉啊....

  • 其他回帖
  • xcatliu 1

    @88250 也可以用机器识别标题和内容是不是一样的。毕竟人总有犯错的时候……

  • ss 1
    作者

    @88250 啊,原来啊。木事,再写一次就行了啊。不过建议老大给文章添加个状态啥的,如果觉得文章不太好的话,标记个状态,排名下降一点,然后通知用户检查一下,等待时间足够长的话用户没有反应然后移到垃圾箱。等待用户自己处理~

  • ss 1
    作者

    @88250 老大,为啥两篇文章少了一篇呢,那一篇《单循环链表》的不见了呢?

推荐标签 标签

  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 2 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 31 回帖 • 8 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 141 关注
  • 安全

    安全永远都不是一个小问题。

    191 引用 • 813 回帖 • 1 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 65 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 688 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 396 关注
  • OnlyOffice
    4 引用 • 12 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 430 关注
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖 • 160 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 2 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 19 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    109 引用 • 54 回帖 • 3 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    402 引用 • 3521 回帖 • 1 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    76 引用 • 429 回帖
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    544 引用 • 3531 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 458 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 237 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    76 引用 • 37 回帖
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    311 引用 • 546 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    328 引用 • 1715 回帖 • 4 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 705 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 330 关注