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
How to change two letters closest to a string and one letter immediately after a string using notepad++
How could a scammer know the apps on my phone / iTunes account?
How to use deus ex machina safely?
In a future war, an old lady is trying to raise a boy but one of the weapons has made everyone deaf
Time travel from stationary position?
Can I use USB data pins as power source
How to deal with taxi scam when on vacation?
Gantt Chart like rectangles with log scale
What is the significance behind "40 days" that often appears in the Bible?
Look at your watch and tell me what time is it. vs Look at your watch and tell me what time it is
Is a party consisting of only a bard, a cleric, and a warlock functional long-term?
compactness of a set where am I going wrong
Happy pi day, everyone!
Are there verbs that are neither telic, or atelic?
Combining an idiom with a metonymy
What exactly is this small puffer fish doing and how did it manage to accomplish such a feat?
Do I need life insurance if I can cover my own funeral costs?
A sequence that has integer values for prime indexes only:
Why doesn't using two cd commands in bash script execute the second command?
Why doesn't the EU now just force the UK to choose between referendum and no-deal?
Is this a real picture of Jordan Peterson in New Zealand with a fan wearing a shirt that says "I'm a Proud Islamaphobe"?
Define, (actually define) the "stability" and "energy" of a compound
Could the Saturn V actually have launched astronauts around Venus?
What options are left, if Britain cannot decide?
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
$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?
scala
New contributor
$endgroup$
add a comment |
$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?
scala
New contributor
$endgroup$
add a comment |
$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?
scala
New contributor
$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
scala
New contributor
New contributor
New contributor
asked 1 hour ago
Aashish DattaniAashish Dattani
1
1
New contributor
New contributor
add a comment |
add a comment |
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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.
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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