欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Kotlin中Stack與LinkedList的實現(xiàn)方法示例

 更新時間:2018年06月01日 09:57:45   作者:LESS IS MORE  
這篇文章主要給大家介紹了關(guān)于Kotlin中Stack與LinkedList實現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

本文主要介紹的是關(guān)于Kotlin 實現(xiàn)基本的數(shù)據(jù)結(jié)構(gòu) Stack 和 LinkedList,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。

Stack

Java中Stack由List實現(xiàn),Kotlin中有MutableList,Stack類的基本定義如下,繼承Iterator為了迭代遍歷:

class Stack<T : Comparable<T>>(list : MutableList<T>) : Iterator<T> 

基本屬性實現(xiàn)

// stack的count
 var itCounter: Int = 0

// stack內(nèi)部實現(xiàn)為MutableList
 var items: MutableList<T> = list

// 判斷stack是否為null
fun isEmpty(): Boolean = this.items.isEmpty()

// 獲取stack的items counte
fun count(): Int = this.items.count()

// tostring操作
 override fun toString(): String {
  return this.items.toString()
 }

基本操作實現(xiàn)

// pop操作,彈出棧頂元素即鏈表最末端元素,可為null
 fun pop(): T? {
 if (this.isEmpty()) {
  return null
 } else {
  val item = this.items.count() - 1
  return this.items.removeAt(item)
 }
}

// 只讀操作,不彈出
fun peek(): T? {
 if (isEmpty()) {
  return null
 } else {
  return this.items[this.items.count() - 1]
 }


}

// hasNext操作
override fun hasNext(): Boolean {
 val hasNext = itCounter < count()
 if (!hasNext) itCounter = 0
 return hasNext
}

// 取next元素
override fun next(): T {
 if (hasNext()){
  val topPos : Int = (count() - 1) - itCounter
  itCounter++
  return this.items[topPos]
 }else{
  throw NoSuchElementException("No such element") // 異常不用new哦
 }
}

LinkedList

LinkedList的實現(xiàn)需要Node,然后實現(xiàn)first、last、count以及append等操作。

Node 定義

class Node<T>(value : T){
 var value : T = value // value可以是任意類型
 var next : Node<T>? = null // next可以為null
 var previous : Node<T>? = null // pre也可以為null
}

基本操作一

// 頭結(jié)點,引導(dǎo)性作用
var head : Node<T>?= null

// 取決于head是否為null
var isEmpty : Boolean = head == null

// 獲取first
fun first() : Node<T>? = head

// 獲取last結(jié)點,需要一直next才能到達last結(jié)點
fun last() : Node<T>?{
 var node = head
 if (node != null){ 
  while (node?.next != null){
   node = node?.next
  }
  return node
 }else{
  return null
 }
}

基本操作二

// 獲取count,同樣通過next計算
fun count():Int {
 var node = head
 if (node != null){
  var counter = 1
  while (node?.next != null){
   node = node?.next
   counter += 1
  }
  return counter
 } else {
  return 0
 }
}

// append操作,在last結(jié)點上append
fun append(value : T){
 var newNode = Node(value)
 // 獲取當(dāng)前節(jié)點的最后一個節(jié)點
 var lastNode = this.last()
 if (lastNode != null){
  newNode.previous = lastNode
  lastNode.next = newNode
 }else{
  head = newNode
 }
}

// 刪除操作
fun removeNode(node : Node<T>) : T{
 val prev = node.previous
 val next = node.next

 if (prev != null){
  prev.next = next
 }else{
  head = next
 }
 next?.previous = prev

 node.previous = null // 將斷開的節(jié)點前后置null
 node.next = null

 return node.value // 返回刪除節(jié)點的value
}

以上,用kotlin實現(xiàn)基本的數(shù)據(jù)結(jié)構(gòu)stack和linkedlist.

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Android利用ViewDragHelper輕松實現(xiàn)拼圖游戲的示例

    Android利用ViewDragHelper輕松實現(xiàn)拼圖游戲的示例

    本篇文章主要介紹了Android利用ViewDragHelper輕松實現(xiàn)拼圖游戲的示例,非常具有實用價值,需要的朋友可以參考下
    2017-11-11
  • 如何修改Android Studio創(chuàng)建module時默認(rèn)的compileSdkVersion

    如何修改Android Studio創(chuàng)建module時默認(rèn)的compileSdkVersion

    這篇文章主要給大家介紹了如何修改Android Studio創(chuàng)建module時默認(rèn)的compileSdkVersion的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-05-05
  • Android開發(fā)Flutter?桌面應(yīng)用窗口化實戰(zhàn)示例

    Android開發(fā)Flutter?桌面應(yīng)用窗口化實戰(zhàn)示例

    這篇文章主要為大家介紹了Android開發(fā)Flutter?桌面應(yīng)用窗口化實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Android中系統(tǒng)自帶鎖WalkLock與KeyguardLock用法實例詳解

    Android中系統(tǒng)自帶鎖WalkLock與KeyguardLock用法實例詳解

    這篇文章主要介紹了Android中系統(tǒng)自帶鎖WalkLock與KeyguardLock用法,結(jié)合實例形式較為詳細(xì)的分析了WalkLock與KeyguardLock的功能、作用、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2016-01-01
  • Android UI效果之繪圖篇(一)

    Android UI效果之繪圖篇(一)

    這篇文章主要介紹了Android UI效果之繪圖篇,針對Android開發(fā)中的UI效果設(shè)計模塊進行講解,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Android圖片處理實例分析

    Android圖片處理實例分析

    這篇文章主要介紹了Android圖片處理的方法,結(jié)合實例形式分析了Android針對圖片的加載、分割、縮放、繪制等操作技巧,需要的朋友可以參考下
    2016-08-08
  • Android Notification通知使用詳解

    Android Notification通知使用詳解

    消息通知(Notification)是Android系統(tǒng)中比較有特色的一個功能,當(dāng)某個應(yīng)用程序希望用戶發(fā)出一些提示信息,而該應(yīng)用又不在前臺運行時,就可以借助通知來實現(xiàn)
    2022-09-09
  • 詳解Android觀察者模式的使用與優(yōu)劣

    詳解Android觀察者模式的使用與優(yōu)劣

    這篇文章主要介紹了Android觀察者模式的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)Android的設(shè)計模式,感興趣的朋友可以了解下
    2020-09-09
  • Android開發(fā)之Animations動畫用法實例詳解

    Android開發(fā)之Animations動畫用法實例詳解

    這篇文章主要介紹了Android開發(fā)之Animations動畫用法,結(jié)合實例形式詳細(xì)分析了Animations動畫的類型、組成、模式及對應(yīng)的使用技巧,需要的朋友可以參考下
    2016-02-02
  • Android中Parcelable的使用詳解

    Android中Parcelable的使用詳解

    Serializable是Java為我們提供的一個標(biāo)準(zhǔn)化的序列化接口。而Parcelable是Android為我們提供的序列化的接口。 這篇文章主要介紹了Android中Parcelable的使用 ,需要的朋友可以參考下
    2019-06-06

最新評論