-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLista.cs
74 lines (70 loc) · 2.25 KB
/
Lista.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ListaDuplamenteEncadeada
{
class Lista
{
private Elemento inicio;
public void adicionar(Clube clube)
{
if (this.inicio == null)
{
this.inicio = new Elemento(clube);
} else
{
Elemento elemento = this.inicio;
while(elemento.GetProximo() != null)
{
elemento = elemento.GetProximo();
}
elemento.SetProximo(new Elemento(clube));
elemento.GetProximo().setAnterior(elemento);
}
}
public void listar()
{
Elemento elemento = this.inicio;
Console.WriteLine(elemento.GetClube().Nome);
while(elemento.GetProximo() != null)
{
elemento = elemento.GetProximo();
Console.WriteLine(elemento.GetClube().Nome);
}
while(elemento.GetAnterior() != null)
{
elemento = elemento.GetAnterior();
Console.WriteLine(elemento.GetClube().Nome);
}
}
public void remover(string nome)
{
Elemento elemento = this.inicio;
if (elemento.GetClube().Nome.Equals(nome))
{
this.inicio = elemento.GetProximo();
this.inicio.setAnterior(null);
} else
{
while (elemento != null)
{
if (elemento.GetClube().Nome.Equals(nome))
{
if (elemento.GetProximo() != null)
{
elemento.GetAnterior().SetProximo(elemento.GetProximo());
elemento.GetProximo().setAnterior(elemento.GetAnterior());
} else
{
elemento.GetAnterior().SetProximo(null);
}
}
elemento = elemento.GetProximo();
}
}
Console.WriteLine("Clube removido: "+nome);
}
}
}