亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

前言

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

Stack

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

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

基本屬性實(shí)現(xiàn)

// stack的count
 var itCounter: Int = 0

// stack內(nèi)部實(shí)現(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()
 }

基本操作實(shí)現(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的實(shí)現(xiàn)需要Node,然后實(shí)現(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é)點(diǎn),引導(dǎo)性作用
var head : Node<T>?= null

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

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

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

基本操作二

// 獲取count,同樣通過(guò)next計(jì)算
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é)點(diǎn)上append
fun append(value : T){
 var newNode = Node(value)
 // 獲取當(dāng)前節(jié)點(diǎn)的最后一個(gè)節(jié)點(diǎn)
 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 // 將斷開(kāi)的節(jié)點(diǎn)前后置null
 node.next = null

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

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

總結(jié)

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

    Android UI效果之繪圖篇(一)

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

    Android圖片處理實(shí)例分析

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

    Android Notification通知使用詳解

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

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

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

    Android開(kāi)發(fā)之Animations動(dòng)畫用法實(shí)例詳解

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

    Android中Parcelable的使用詳解

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

最新評(píng)論