C
C#15mo ago
Mayonaize

❔ Removing dupes in a linked list

I need to make a function that gets a linked list, and returns that linked list with all sequences of 3 or more consecutive equal numbers be removed for example: 1,3,3,3,4,5,5,6,9,9,9,9 becomes 1,4,5,5,6
129 Replies
JakenVeina
JakenVeina15mo ago
$details
MODiX
MODiX15mo ago
When you ask a question, make sure you include as much detail as possible. Such as code, the issue you are facing, and what you expect the result to be. Upload code here https://paste.mod.gg/ (see $code for more information on how to paste your code)
Mayonaize
MayonaizeOP15mo ago
well i dont have any code written as i dont have an idea as to were to start sadly thats also my issue
JakenVeina
JakenVeina15mo ago
alright let's break down the problem
Mayonaize
MayonaizeOP15mo ago
I have a very vague idea but no more than that
JakenVeina
JakenVeina15mo ago
gotta start somewhere what is your vague idea?
Mayonaize
MayonaizeOP15mo ago
so
Mayonaize
MayonaizeOP15mo ago
first thing is
No description
Mayonaize
MayonaizeOP15mo ago
p1 being a pointer on first object p2 on the one after and inside that if clause i would put it into a new list hold on ill write it so its more clear
JakenVeina
JakenVeina15mo ago
so A) your plan is to build a new list, rather than trying to modify the existing one
Mayonaize
MayonaizeOP15mo ago
No description
Mayonaize
MayonaizeOP15mo ago
yeah thats what they want in the question, sorry i didnt specify
JakenVeina
JakenVeina15mo ago
great
Mayonaize
MayonaizeOP15mo ago
although it really doesnt matter since i can make a copy of the old list i have a function for that
JakenVeina
JakenVeina15mo ago
you're allowed to use the built-in LinkedList here, or you have to write your own?
Mayonaize
MayonaizeOP15mo ago
nope we use the one the teacher built i can send you it if you want
JakenVeina
JakenVeina15mo ago
please do $code
MODiX
MODiX15mo ago
To post C# code type the following: ```cs // code here ``` Get an example by typing $codegif in chat For longer snippets, use: https://paste.mod.gg/
Mayonaize
MayonaizeOP15mo ago
public class Node<T>
{
private T value; // Node value
private Node<T> next; // next Node

/* Constructor - returns a Node with "value" as value and without successesor Node **/
public Node(T value)
{
this.value = value;
this.next = null;
}

/* Constructor - returns a Node with "value" as value and its successesor is "next" **/
public Node(T value, Node<T> next)
{
this.value = value;
this.next = next;
}

/* Returns the Node "value" **/
public T GetValue()
{
return this.value;
}

/* Returns the Node "next" Node **/
public Node<T> GetNext()
{
return this.next;
}

/* Return if the current Node Has successor **/
public bool HasNext()
{
return (this.next != null);
}

/* Set the value attribute to be "value" **/
public void SetValue(T value)
{
this.value = value;
}

/* Set the next attribute to be "next" **/
public void SetNext(Node<T> next)
{
this.next = next;
}

/* Returns a string that describes the Node (and its' successesors **/
public override string ToString()
{
return value + "-->" + next;

}
}
public class Node<T>
{
private T value; // Node value
private Node<T> next; // next Node

/* Constructor - returns a Node with "value" as value and without successesor Node **/
public Node(T value)
{
this.value = value;
this.next = null;
}

/* Constructor - returns a Node with "value" as value and its successesor is "next" **/
public Node(T value, Node<T> next)
{
this.value = value;
this.next = next;
}

/* Returns the Node "value" **/
public T GetValue()
{
return this.value;
}

/* Returns the Node "next" Node **/
public Node<T> GetNext()
{
return this.next;
}

/* Return if the current Node Has successor **/
public bool HasNext()
{
return (this.next != null);
}

/* Set the value attribute to be "value" **/
public void SetValue(T value)
{
this.value = value;
}

/* Set the next attribute to be "next" **/
public void SetNext(Node<T> next)
{
this.next = next;
}

/* Returns a string that describes the Node (and its' successesors **/
public override string ToString()
{
return value + "-->" + next;

}
}
srry its long
JakenVeina
JakenVeina15mo ago
lovely
Mayonaize
MayonaizeOP15mo ago
very i feel like i need a nested loop here or another function that i build
JakenVeina
JakenVeina15mo ago
possibly there's a variety of ways you could do this let's think about the problem first
Mayonaize
MayonaizeOP15mo ago
Can i tell you the idea i thought of just now with the nested loop ?
JakenVeina
JakenVeina15mo ago
you have to build a list from a set of input numbers
Mayonaize
MayonaizeOP15mo ago
or do you wanna do this first i might have overlooked something well i just like i copied the example it gave me
JakenVeina
JakenVeina15mo ago
right
Mayonaize
MayonaizeOP15mo ago
int[] arr = { 1, 3,3,3,4,5,5,6,9,9,9,9};
Node<int> list = CreateList(arr);
int[] arr = { 1, 3,3,3,4,5,5,6,9,9,9,9};
Node<int> list = CreateList(arr);
JakenVeina
JakenVeina15mo ago
where it should ignore any sequences of the same consecutive number, longer than 3 so
Mayonaize
MayonaizeOP15mo ago
yep
JakenVeina
JakenVeina15mo ago
what are you going to need here that you KNOW
Mayonaize
MayonaizeOP15mo ago
ok so definitely a counter
JakenVeina
JakenVeina15mo ago
maybe even more fundamental than that
Mayonaize
MayonaizeOP15mo ago
do you not think so? um
JakenVeina
JakenVeina15mo ago
not sure
Mayonaize
MayonaizeOP15mo ago
while loop?
JakenVeina
JakenVeina15mo ago
some kinda loop, for sure to iterate the input numbers
Mayonaize
MayonaizeOP15mo ago
yeah and to make sure i dont reach null right?
JakenVeina
JakenVeina15mo ago
what does "reach null" mean?
Mayonaize
MayonaizeOP15mo ago
i mean like the list ends at some point
JakenVeina
JakenVeina15mo ago
which list?
Mayonaize
MayonaizeOP15mo ago
any list i gues s i mean like after the 9 it points to null
JakenVeina
JakenVeina15mo ago
nnnno, that array does not have any nulls in it
Mayonaize
MayonaizeOP15mo ago
nonono not the array i create a list with the values from the array i can send you that function as well if you want
JakenVeina
JakenVeina15mo ago
okay, but what does that have to do with what we're talking about
Mayonaize
MayonaizeOP15mo ago
public static Node<T> CreateList<T>(T[] arr)
{
Node<T> n = new Node<T> (arr[0]);
Node<T> first = n;
Node<T> p = n;
for (int i = 1; i < arr.Length; i++)
{
n = new Node<T>(arr[i]);
p.SetNext(n);
p = p.GetNext();
}
return first;
}
public static Node<T> CreateList<T>(T[] arr)
{
Node<T> n = new Node<T> (arr[0]);
Node<T> first = n;
Node<T> p = n;
for (int i = 1; i < arr.Length; i++)
{
n = new Node<T>(arr[i]);
p.SetNext(n);
p = p.GetNext();
}
return first;
}
JakenVeina
JakenVeina15mo ago
some kinda loop, for sure to iterate the input numbers
Mayonaize
MayonaizeOP15mo ago
ok yeah i understand why
JakenVeina
JakenVeina15mo ago
there's no nulls involved in iterating the input, if the input is an array
Mayonaize
MayonaizeOP15mo ago
it isnt an array its a linked list
JakenVeina
JakenVeina15mo ago
the input is?
Mayonaize
MayonaizeOP15mo ago
no look here i made a list out of the array and then i call the function on the list
JakenVeina
JakenVeina15mo ago
why?
Mayonaize
MayonaizeOP15mo ago
idk thats what they want me to do
JakenVeina
JakenVeina15mo ago
okay so the input is, in fact, a linked list
Mayonaize
MayonaizeOP15mo ago
ye
JakenVeina
JakenVeina15mo ago
and we are trying to build a new list from that yes?
Mayonaize
MayonaizeOP15mo ago
yeah
JakenVeina
JakenVeina15mo ago
so, again let's start with what we KNOW
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{

}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{

}
Mayonaize
MayonaizeOP15mo ago
So
JakenVeina
JakenVeina15mo ago
and then we said, we KNOW we need to at least iterate all the nodes in the input list so go ahead and write that loop
Mayonaize
MayonaizeOP15mo ago
ok so like a while loop or for loop I would do likeeee
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int> iterator = listHead;
while(listHead !=null)
{
iterator = iterator.GetNext();
}
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int> iterator = listHead;
while(listHead !=null)
{
iterator = iterator.GetNext();
}
}
is that ok or would you do something different
JakenVeina
JakenVeina15mo ago
for clarity, I would recommend A) not modifying input parameters, just in general B) not using a variable named listHead to represent something that isn't the head of a list
Mayonaize
MayonaizeOP15mo ago
so make a copy first?
JakenVeina
JakenVeina15mo ago
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var currentNode = listHead;
while(currentNode != null)
{
currentNode = currentNode.GetNext();
}
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var currentNode = listHead;
while(currentNode != null)
{
currentNode = currentNode.GetNext();
}
}
Mayonaize
MayonaizeOP15mo ago
oh yeah that seems better
JakenVeina
JakenVeina15mo ago
clarifies your intention so what else do we know? about this method
Mayonaize
MayonaizeOP15mo ago
um that we have to compare values ?
JakenVeina
JakenVeina15mo ago
true what else?
Mayonaize
MayonaizeOP15mo ago
ummmmm well i have to create a new list
JakenVeina
JakenVeina15mo ago
even more specifically, we have to return it
Mayonaize
MayonaizeOP15mo ago
oh yeah right so like
JakenVeina
JakenVeina15mo ago
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int>? resultHead = null;

var currentNode = listHead;
while(currentNode != null)
{
currentNode = currentNode.GetNext();
}

return resultHead;
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int>? resultHead = null;

var currentNode = listHead;
while(currentNode != null)
{
currentNode = currentNode.GetNext();
}

return resultHead;
}
Mayonaize
MayonaizeOP15mo ago
yeah ok wait what is that question mark
JakenVeina
JakenVeina15mo ago
indicates that the value can be null
Mayonaize
MayonaizeOP15mo ago
wait what does that mean sorry like what if i just do that without ? thats what ive been doing
JakenVeina
JakenVeina15mo ago
what version of .NET/C# are you using?
Mayonaize
MayonaizeOP15mo ago
ummmm i think 4.7.1
JakenVeina
JakenVeina15mo ago
(look at your .csproj)
Mayonaize
MayonaizeOP15mo ago
wait lemme check um\
Mayonaize
MayonaizeOP15mo ago
in here
No description
JakenVeina
JakenVeina15mo ago
close enough you're on .NET Framework
Mayonaize
MayonaizeOP15mo ago
oh yeah
JakenVeina
JakenVeina15mo ago
sigh why do universities insist on teaching people exlusively on out-of-date technology
Mayonaize
MayonaizeOP15mo ago
im in highschool :( and its not my teacher its like the ministry of education
JakenVeina
JakenVeina15mo ago
so, ignore the nullability thing, that was introduced to C# only somewhat recently and it's an optional feature, anyway
Mayonaize
MayonaizeOP15mo ago
kk alr
JakenVeina
JakenVeina15mo ago
so now, we have a basic structure for the method what next?
Mayonaize
MayonaizeOP15mo ago
I would like try to see how we compare the values while putting them into the new list
JakenVeina
JakenVeina15mo ago
compare what values?
Mayonaize
MayonaizeOP15mo ago
well each time we compare different values
JakenVeina
JakenVeina15mo ago
each time what? think about it more fundamentally you have a loop
Mayonaize
MayonaizeOP15mo ago
each iteration we compare 2 different values
JakenVeina
JakenVeina15mo ago
over each item in the input list yeah, what is it that we need to DO within each iteration? so
Mayonaize
MayonaizeOP15mo ago
well a couple of things right?
JakenVeina
JakenVeina15mo ago
each iteration we compare 2 different values
which 2 different values?
Mayonaize
MayonaizeOP15mo ago
um like say the linked list is 1-> 2 ->2->3 then like 1st iteration: 1,2 2nd: 2,2 3rd: 2,3 idk how to put it into words
JakenVeina
JakenVeina15mo ago
so, from the perspective of a single iteration what are we comparing
Mayonaize
MayonaizeOP15mo ago
ummmmmmmm the value of currentNode and the next current node
JakenVeina
JakenVeina15mo ago
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int>? resultHead = null;

var currentNode = listHead;
while(currentNode != null)
{
// compare 2 values

currentNode = currentNode.GetNext();
}

return resultHead;
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
Node<int>? resultHead = null;

var currentNode = listHead;
while(currentNode != null)
{
// compare 2 values

currentNode = currentNode.GetNext();
}

return resultHead;
}
that'll work you could also consider it "the current node and the previous node"
Mayonaize
MayonaizeOP15mo ago
rightttt that seems better
JakenVeina
JakenVeina15mo ago
maybe both are valid
Mayonaize
MayonaizeOP15mo ago
alr so we add another variable? or do we use current node
JakenVeina
JakenVeina15mo ago
which approach are you going with?
Mayonaize
MayonaizeOP15mo ago
i think ill go with previous and current it seems easier
JakenVeina
JakenVeina15mo ago
so, how do we retrieve the previous node, from the current node?
Mayonaize
MayonaizeOP15mo ago
oh well i guess we cant really
JakenVeina
JakenVeina15mo ago
righto
Mayonaize
MayonaizeOP15mo ago
at least not in this linked list its not an option for us
JakenVeina
JakenVeina15mo ago
not directly, yes
Mayonaize
MayonaizeOP15mo ago
um i have an idea so before the loop we add another variable prevNode hold ill just write it down
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var currentNode = listHead;
var prevNode = currentNode;
currentNode = currentNode.GetNext();
while (currentNode != null)
{
currentNode = currentNode.GetNext();
prevNode = currentNode;
}
return listHead;
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var currentNode = listHead;
var prevNode = currentNode;
currentNode = currentNode.GetNext();
while (currentNode != null)
{
currentNode = currentNode.GetNext();
prevNode = currentNode;
}
return listHead;
}
would this be fine? or is there something better
JakenVeina
JakenVeina15mo ago
well that's wrong, for starters well no that would work assuming you always HAVE a first node NOW it's wrong
Mayonaize
MayonaizeOP15mo ago
like ur saying i might have a list with 1 value? or no values?
JakenVeina
JakenVeina15mo ago
you tell me can those things happen?
Mayonaize
MayonaizeOP15mo ago
well yeah i guess
JakenVeina
JakenVeina15mo ago
how would your code handle it?
Mayonaize
MayonaizeOP15mo ago
crash like not run
JakenVeina
JakenVeina15mo ago
no, not exactly what happens if listHead is null?
Mayonaize
MayonaizeOP15mo ago
then this wouldnt work right?
No description
JakenVeina
JakenVeina15mo ago
yup, that'll throw NullReferenceException
Mayonaize
MayonaizeOP15mo ago
hmmm ok so how do we fix that lemme think
JakenVeina
JakenVeina15mo ago
what if listHead.GetNext() is null?
Mayonaize
MayonaizeOP15mo ago
do we just add an if? well it would run
JakenVeina
JakenVeina15mo ago
you can indeed, it'll run completely fine for a list with 1 item
Mayonaize
MayonaizeOP15mo ago
but it wouldnt even go into the loop
JakenVeina
JakenVeina15mo ago
right I mean, except for the fact that we aren't doing anything to build the new list, yet
Mayonaize
MayonaizeOP15mo ago
well yeah
JakenVeina
JakenVeina15mo ago
I gotta go make dinner, fill me in on your progress when I get back
Mayonaize
MayonaizeOP15mo ago
alr ill try ty i really apprecaite it ooooo i have an idea on how to fix the NullReference thingy
var resultHead = new Node<int>(0, listHead);
var prevNode = resultHead;
var currentNode = listHead;
var resultHead = new Node<int>(0, listHead);
var prevNode = resultHead;
var currentNode = listHead;
and i might have gotten an idea for the nested loop but idk i gotta see first like i wanna use a previous and a next and a current maybe that might work but only initalize the next node in the loop so i can like i wanna use nextNode to iterate inside the loop until the thingy changes then i can change currentnode to next node i also think it might be better to delete thingies cuz idk how to do it otherwise ima try what io have in imnd and come back and like use previous to link the thingies idk how to explainw ith words ok so i think i got it maybe i have a mistake but what i did kinda like links next node and prev node and like if it doesnt i guess i need to change prev current? but only if it doesnt? wait maybe not to next but to current? ok i think i might have got it
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var resultHead = new Node<int>(0, listHead);
var prevNode = resultHead;
var currentNode = listHead;

currentNode = currentNode.GetNext();
while (currentNode != null)
{
Node<int> nextNode = currentNode.GetNext();
int counter = 1;
while (nextNode != null && currentNode.GetValue() == nextNode.GetValue())
{
counter++;
nextNode = nextNode.GetNext();
}
if (counter >= 3){prevNode.SetNext(nextNode);}

else {prevNode = currentNode;}

currentNode = nextNode;

currentNode = currentNode.GetNext(); //If nodes get deleted it goes straight to the place after deletion, if not it goes the the place after checking the duplicates.
}
return listHead;
}
public Node<int> DuplicateListWithoutConsecutiveValueSequencesLongerThan2(Node<int> listHead)
{
var resultHead = new Node<int>(0, listHead);
var prevNode = resultHead;
var currentNode = listHead;

currentNode = currentNode.GetNext();
while (currentNode != null)
{
Node<int> nextNode = currentNode.GetNext();
int counter = 1;
while (nextNode != null && currentNode.GetValue() == nextNode.GetValue())
{
counter++;
nextNode = nextNode.GetNext();
}
if (counter >= 3){prevNode.SetNext(nextNode);}

else {prevNode = currentNode;}

currentNode = nextNode;

currentNode = currentNode.GetNext(); //If nodes get deleted it goes straight to the place after deletion, if not it goes the the place after checking the duplicates.
}
return listHead;
}
i really hope this works cuz i gotta go sleep its 2:30 am doesnt workkkk mannnnn i needs go to sleep i got school in 5 hours Thank you so mcuh for the help i really really really appreciate it ill go over this tmrw again tysm good night
Accord
Accord15mo ago
Was this issue resolved? If so, run /close - otherwise I will mark this as stale and this post will be archived until there is new activity.

Did you find this page helpful?