LinkedList :


  1. /**
  2. * 考虑的比较的周全,并且包含了全部的情况,代码也不乱<b></b>
  3. *
  4. * @param index
  5. * 插入的位置
  6. * @param c
  7. * 插入的元素集合
  8. */
  9. private boolean addAll(int index, Collection<? extends E> c) {
  10. // 缺少对于size的参数的校验
  11. Object[] a = c.toArray();
  12. int numNew = a.length;
  13. if (numNew == 0)
  14. return false;
  15. // 确定插入的位置和插入的前一个位置
  16. Node<E> pred, succ;
  17. if (index == size) {
  18. succ = null;
  19. pred = last;
  20. } else {
  21. succ = node(index);
  22. pred = succ.prev;
  23. }
  24. // 首先就是能够确认自己前面的一个节点是谁,size指的是插入的位置,后面的全部的一次
  25. // 向后移动
  26. for (Object o : a) {
  27. @SuppressWarnings("unchecked")
  28. E e = (E) o;
  29. Node<E> newNode = new Node<E>(pred, e, null);
  30. if (pred == null)
  31. first = newNode;
  32. else
  33. pred.next = newNode;
  34. pred = newNode;
  35. }
  36. // 把插入后面的元素接上
  37. if (succ == null) {
  38. last = pred;
  39. } else {
  40. pred.next = succ;
  41. succ.prev = pred;
  42. }
  43. size += numNew;
  44. return true;
  45. }
  46. /**
  47. * Returns the (non-null) Node at the specified element index. the alg is
  48. * interesting
  49. */
  50. private Node<E> node(int index) {
  51. if (index < (size >> 1)) {// 前半截,后半截
  52. Node<E> x = first;
  53. for (int i = 0; i < index; i++)
  54. x = x.next;
  55. return x;
  56. } else {
  57. Node<E> x = last;
  58. for (int i = size - 1; i > index; i--)
  59. x = x.prev;
  60. return x;
  61. }
  62. }

add function 代码写的还是比较的精彩的:
  1. public boolean add(E e) {
  2. linkLast(e);
  3. return true;
  4. }
  5. /**
  6. * @param e
  7. */
  8. private void linkLast(E e) {
  9. // 尾节点,final ?
  10. final Node<E> l = last;
  11. final Node<E> newNode = new Node<E>(l, e, null);
  12. last = newNode;
  13. // special situation
  14. if (l == null)
  15. first = newNode;
  16. else
  17. l.next = newNode;
  18. size++;
  19. }
  20. /**
  21. * Inserts the specified element at the specified position in this list.
  22. * Shifts the element currently at that position (if any) and any subsequent
  23. * elements to the right (adds one to their indices).
  24. *
  25. * @param index
  26. * index at which the specified element is to be inserted
  27. * @param element
  28. * element to be inserted
  29. * @throws IndexOutOfBoundsException
  30. * {@inheritDoc}
  31. */
  32. public void add(int index, E element) {
  33. checkPositionIndex(index);
  34. if (index == size)
  35. linkLast(element);
  36. else
  37. linkBefore(element, node(index));
  38. }
  39. private void linkBefore(E element, Node<E> succ) {
  40. // assert succ != null;
  41. final Node<E> pred = succ.prev;
  42. final Node<E> insert = new Node<E>(pred, element, succ);
  43. succ.prev = insert;
  44. if (pred == null)
  45. first = insert;
  46. else
  47. pred.next = insert;
  48. size++;
  49. }
  50. private boolean isPositionIndex(int index) {
  51. return index >= 0 && index <= size;
  52. }
  53. private void checkPositionIndex(int index) {
  54. if (!isPositionIndex(index))
  55. throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
  56. }
  57. private String outOfBoundsMsg(int index) {
  58. return "Index: " + index + ", Size: " + size;
  59. }


Foundation Data Structure的更多相关文章

  1. [LeetCode] All O`one Data Structure 全O(1)的数据结构

    Implement a data structure supporting the following operations: Inc(Key) - Inserts a new key with va ...

  2. [LeetCode] Add and Search Word - Data structure design 添加和查找单词-数据结构设计

    Design a data structure that supports the following two operations: void addWord(word) bool search(w ...

  3. [LeetCode] Two Sum III - Data structure design 两数之和之三 - 数据结构设计

    Design and implement a TwoSum class. It should support the following operations:add and find. add - ...

  4. Finger Trees: A Simple General-purpose Data Structure

    http://staff.city.ac.uk/~ross/papers/FingerTree.html Summary We present 2-3 finger trees, a function ...

  5. Mesh Data Structure in OpenCascade

    Mesh Data Structure in OpenCascade eryar@163.com 摘要Abstract:本文对网格数据结构作简要介绍,并结合使用OpenCascade中的数据结构,将网 ...

  6. ✡ leetcode 170. Two Sum III - Data structure design 设计two sum模式 --------- java

    Design and implement a TwoSum class. It should support the following operations: add and find. add - ...

  7. leetcode Add and Search Word - Data structure design

    我要在这里装个逼啦 class WordDictionary(object): def __init__(self): """ initialize your data ...

  8. Java for LeetCode 211 Add and Search Word - Data structure design

    Design a data structure that supports the following two operations: void addWord(word)bool search(wo ...

  9. HDU5739 Fantasia(点双连通分量 + Block Forest Data Structure)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5739 Description Professor Zhang has an undirect ...

随机推荐

  1. [Android] Service和IntentService中显示Toast的区别

    1. 表象     Service中可以正常显示Toast,IntentService中不能正常显示Toast,在2.3系统上,不显示toast,在4.3系统上,toast显示,但是不会消失. 2. ...

  2. HDFS Architecture--官方文档

    HDFS Architecture Introduction The Hadoop Distributed File System (HDFS) is a distributed file syste ...

  3. MVC模式下的数据展示:EasyUI的datagrid

    我的数据库设计是一张老师表teacher,一张学生表student,一个教师对应多个学生,在学生一方建立外键; 还有一点想清楚,需要展示的数据是根据什么来的,是成功登陆的用户的id?还是直接展示所有的 ...

  4. discuz! X3 门户文章添加字段

    1. 首先需要去数据表里[llgp_portal_article_title]手动添加需要添加的字段. (注意: 数据表前缀依据自己的设置而定) 2. 修改模版template\default\por ...

  5. 如何在ASP.NET端获取屏幕宽度

    using System.Windows.Forms; 首先引用上面的命名空间. 然后在代码中获取屏幕信息.如下代码: System.Windows.Forms.Screen screen = Sys ...

  6. DWZ框架学习一

    测试DWZ框架弹出框设置成模态 刚刚上手DWZ框架,感觉灰常好用,对于我这种特别懒的人来说,真的是拖拽编程 看了下官方的视频讲解,自己试着做了一个小测试,里面的组件什么的都不用写,直接拿来用 这里附上 ...

  7. My First Blog.

    I just wanna mark my first blog in order to have a wonderful memories in the future.

  8. Android中使用PullToRefreshListView遇到的问题

    1.布局文件中要是设置visible属性为Gone的时候,注意了,这样会有一个bug,在代码中setVisible的时候设置为VISIBLE是不起作用的..这个应该是自身的一个小bug(本人目前没有找 ...

  9. jrae源码解析(二)

    本文细述上文引出的RAECost和SoftmaxCost两个类. SoftmaxCost 我们已经知道,SoftmaxCost类在给定features和label的情况下(超参数给定),衡量给定权重( ...

  10. [转] UIImage 图像-IOS开发 (实例)

    转自  http://justcoding.iteye.com/blog/1470931 一 UIImageView 简介 UIImageView是显示图片的控件,显示图片时,首先需要把图片加载到UI ...