Mutable Linked List in ScalaScala list foldingIdeal FP/Scala way to vaildate rectangular listSingly linked list implementation in ScalaScala list to tuple conversionDivide list into n parts in scalaCheck if a linked list is a palindrome in ScalaSingly linked list in ScalaImplementation of linked list in ScalaScala tic-tac-toe no mutable stateFixed size double linked list in Scala

Look at your watch and tell me what time is it. vs Look at your watch and tell me what time it is

Why Choose Less Effective Armour Types?

Happy pi day, everyone!

PTIJ: Who should I vote for? (21st Knesset Edition)

What has been your most complicated TikZ drawing?

Define, (actually define) the "stability" and "energy" of a compound

Why do Australian milk farmers need to protest supermarkets' milk price?

What's the meaning of “spike” in the context of “adrenaline spike”?

Can I use USB data pins as power source

Should we release the security issues we found in our product as CVE or we can just update those on weekly release notes?

Official degrees of earth’s rotation per day

Sailing the cryptic seas

How to write cleanly even if my character uses expletive language?

Dice rolling probability game

Most cost effective thermostat setting: consistent temperature vs. lowest temperature possible

Life insurance that covers only simultaneous/dual deaths

Co-worker team leader wants to inject his friend's awful software into our development. What should I say to our common boss?

Welcoming 2019 Pi day: How to draw the letter π?

How could a scammer know the apps on my phone / iTunes account?

How do anti-virus programs start at Windows boot?

how to draw discrete time diagram in tikz

My Graph Theory Students

My adviser wants to be the first author

How to explain that I do not want to visit a country due to personal safety concern?



Mutable Linked List in Scala


Scala list foldingIdeal FP/Scala way to vaildate rectangular listSingly linked list implementation in ScalaScala list to tuple conversionDivide list into n parts in scalaCheck if a linked list is a palindrome in ScalaSingly linked list in ScalaImplementation of linked list in ScalaScala tic-tac-toe no mutable stateFixed size double linked list in Scala













0












$begingroup$


Scala newbie here. I'm trying to implement a mutable linked list in Scala. So far, I am only supporting the add() operation. Here's my stab at it:



class MutableList[T] 

class Node[T](val value: T)
var next: Node[T] = null
def hasNext = (next != null)


var first, last: Node[T] = null
var size = 0

def add(value: T) =
val newNode = new Node[T](value)
if (first == null)
assert(size == 0)
first = newNode
last = newNode
else
last.next = newNode

size += 1


override def toString =
def getValues() =
var current = first
for (i <- 1 to size) yield
val valStr = current.value.toString
current = current.next
valStr


getValues().mkString(",")




I know that a mutable data structure is not the best thing to use/implement in Scala. But I'm just experimenting and was wondering if there is a more functional Scala way of writing this?









share







New contributor




Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$
















    0












    $begingroup$


    Scala newbie here. I'm trying to implement a mutable linked list in Scala. So far, I am only supporting the add() operation. Here's my stab at it:



    class MutableList[T] 

    class Node[T](val value: T)
    var next: Node[T] = null
    def hasNext = (next != null)


    var first, last: Node[T] = null
    var size = 0

    def add(value: T) =
    val newNode = new Node[T](value)
    if (first == null)
    assert(size == 0)
    first = newNode
    last = newNode
    else
    last.next = newNode

    size += 1


    override def toString =
    def getValues() =
    var current = first
    for (i <- 1 to size) yield
    val valStr = current.value.toString
    current = current.next
    valStr


    getValues().mkString(",")




    I know that a mutable data structure is not the best thing to use/implement in Scala. But I'm just experimenting and was wondering if there is a more functional Scala way of writing this?









    share







    New contributor




    Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.







    $endgroup$














      0












      0








      0





      $begingroup$


      Scala newbie here. I'm trying to implement a mutable linked list in Scala. So far, I am only supporting the add() operation. Here's my stab at it:



      class MutableList[T] 

      class Node[T](val value: T)
      var next: Node[T] = null
      def hasNext = (next != null)


      var first, last: Node[T] = null
      var size = 0

      def add(value: T) =
      val newNode = new Node[T](value)
      if (first == null)
      assert(size == 0)
      first = newNode
      last = newNode
      else
      last.next = newNode

      size += 1


      override def toString =
      def getValues() =
      var current = first
      for (i <- 1 to size) yield
      val valStr = current.value.toString
      current = current.next
      valStr


      getValues().mkString(",")




      I know that a mutable data structure is not the best thing to use/implement in Scala. But I'm just experimenting and was wondering if there is a more functional Scala way of writing this?









      share







      New contributor




      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.







      $endgroup$




      Scala newbie here. I'm trying to implement a mutable linked list in Scala. So far, I am only supporting the add() operation. Here's my stab at it:



      class MutableList[T] 

      class Node[T](val value: T)
      var next: Node[T] = null
      def hasNext = (next != null)


      var first, last: Node[T] = null
      var size = 0

      def add(value: T) =
      val newNode = new Node[T](value)
      if (first == null)
      assert(size == 0)
      first = newNode
      last = newNode
      else
      last.next = newNode

      size += 1


      override def toString =
      def getValues() =
      var current = first
      for (i <- 1 to size) yield
      val valStr = current.value.toString
      current = current.next
      valStr


      getValues().mkString(",")




      I know that a mutable data structure is not the best thing to use/implement in Scala. But I'm just experimenting and was wondering if there is a more functional Scala way of writing this?







      scala





      share







      New contributor




      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.










      share







      New contributor




      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.








      share



      share






      New contributor




      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 5 mins ago









      Aashish DattaniAashish Dattani

      1




      1




      New contributor




      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      Aashish Dattani is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          0






          active

          oldest

          votes











          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
          );
          );
          , "mathjax-editing");

          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "196"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );






          Aashish Dattani is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215547%2fmutable-linked-list-in-scala%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          Aashish Dattani is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          Aashish Dattani is a new contributor. Be nice, and check out our Code of Conduct.












          Aashish Dattani is a new contributor. Be nice, and check out our Code of Conduct.











          Aashish Dattani is a new contributor. Be nice, and check out our Code of Conduct.














          Thanks for contributing an answer to Code Review Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215547%2fmutable-linked-list-in-scala%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          कुँवर स्रोत दिक्चालन सूची"कुँवर""राणा कुँवरके वंशावली"

          शेव्रोले वोल्ट अनुक्रम इतिहास इन्हे भी देखें चित्र दीर्घा संदर्भ दिक्चालन सूची

          चैत्य भूमि चित्र दीर्घा सन्दर्भ बाहरी कडियाँ दिक्चालन सूची"Chaitya Bhoomi""Chaitya Bhoomi: Statue of Equality in India""Dadar Chaitya Bhoomi: Statue of Equality in India""Ambedkar memorial: Centre okays transfer of Indu Mill land"चैत्यभमि