<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>MixInformatico.com &#187; listas en java</title>
	<atom:link href="http://www.mixinformatico.com/tag/listas-en-java/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.mixinformatico.com</link>
	<description>Reforzando tus ideas</description>
	<lastBuildDate>Sat, 31 Jul 2010 00:47:31 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.2</generator>
		<item>
		<title>Estructura de datos java (Listas simplemente enlazadas)</title>
		<link>http://www.mixinformatico.com/2010/03/25/estructura-de-datos-java-listas-simplemente-enlazadas/</link>
		<comments>http://www.mixinformatico.com/2010/03/25/estructura-de-datos-java-listas-simplemente-enlazadas/#comments</comments>
		<pubDate>Thu, 25 Mar 2010 21:55:39 +0000</pubDate>
		<dc:creator>dementexmaster</dc:creator>
				<category><![CDATA[Java]]></category>
		<category><![CDATA[listas en java]]></category>
		<category><![CDATA[listas java]]></category>
		<category><![CDATA[listas simplemente enlazadas]]></category>

		<guid isPermaLink="false">http://www.mixinformatico.com/?p=8952</guid>
		<description><![CDATA[Empezaremos creando la clase que nos permitira recorrer la lista, a esta le asignaremos el nombre de Nodo 1 2 3 4 5 6 7 8 9 10 public class Nodo &#123; Nodo nodoDer; int dato; &#160; public Nodo&#40;int dato&#41; &#123; this.dato = dato; this.nodoDer = null; &#125; &#160; &#125; Nesesitaremos un nodo para agregar [...]]]></description>
			<content:encoded><![CDATA[<p>Empezaremos creando la clase que nos permitira recorrer la lista, a esta le asignaremos el nombre de Nodo</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">class</span> Nodo <span style="color: #009900;">&#123;</span>
 Nodo nodoDer<span style="color: #339933;">;</span>
 <span style="color: #000066; font-weight: bold;">int</span>  dato<span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">public</span>  Nodo<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> dato<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">dato</span> <span style="color: #339933;">=</span> dato<span style="color: #339933;">;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Nesesitaremos un nodo para agregar a la lista este metodo ira agregando todo al final de la misma:</p>
<p><span id="more-8952"></span></p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span>  ListaS addLast<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> dato<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>siVacio<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 Nodo nuevo <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Nodo<span style="color: #009900;">&#40;</span>dato<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
 primero <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
 ultimo <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
 nuevo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span>  nuevo<span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 <span style="color: #000000; font-weight: bold;">else</span> <span style="color: #009900;">&#123;</span>
 Nodo nuevo <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Nodo<span style="color: #009900;">&#40;</span>dato<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
 nuevo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span>  <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 ultimo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span>  nuevo<span style="color: #339933;">;</span>
 ultimo <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #339933;">++;</span>
 <span style="color: #000000; font-weight: bold;">return</span>  <span style="color: #000000; font-weight: bold;">this</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>De igual forma se nesesita un metodo para borrar datos de la lista:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span>  Nodo deleteLast<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 Nodo eliminar <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>siVacio<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #003399;">JOptionPane</span>.<span style="color: #006633;">showMessageDialog</span><span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">null</span>, <span style="color: #0000ff;">&quot;La lista se encuentra vacia&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
 <span style="color: #000000; font-weight: bold;">return</span>  <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>primero <span style="color: #339933;">==</span> ultimo<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 primero <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 ultimo <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 <span style="color: #000000; font-weight: bold;">else</span> <span style="color: #009900;">&#123;</span>
 Nodo actual <span style="color: #339933;">=</span> primero<span style="color: #339933;">;</span>
 <span style="color: #000000; font-weight: bold;">while</span><span style="color: #009900;">&#40;</span>actual.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">!=</span>  ultimo<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 actual <span style="color: #339933;">=</span> actual.<span style="color: #006633;">nodoDer</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 eliminar <span style="color: #339933;">=</span> actual.<span style="color: #006633;">nodoDer</span><span style="color: #339933;">;</span>
 actual.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span>  <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
&nbsp;
ultimo <span style="color: #339933;">=</span> actual<span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #339933;">--;</span>
 <span style="color: #000000; font-weight: bold;">return</span>  eliminar<span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Nuestro codigo completo quedaria de la siguiente manera:</p>
<p>Classe principal:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>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
75
76
77
78
79
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">import</span> <span style="color: #006699;">javax.swing.JOptionPane</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">class</span> ListaS <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">private</span> Nodo primero<span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">private</span> Nodo ultimo<span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">int</span> tamano<span style="color: #339933;">;</span>
&nbsp;
    <span style="color: #000000; font-weight: bold;">public</span> ListaS<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">primero</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">ultimo</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span> <span style="color: #339933;">=</span> <span style="color: #cc66cc;">0</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">//Metodo utilizado para denotar que la lista se encuentra vacia.</span>
    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">boolean</span> siVacio<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">primero</span> <span style="color: #339933;">==</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">//Metodo para agregar al final de la lista.</span>
    <span style="color: #000000; font-weight: bold;">public</span> ListaS addLast<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> dato<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>siVacio<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            Nodo nuevo <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Nodo<span style="color: #009900;">&#40;</span>dato<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            primero <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
            ultimo <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
            nuevo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        <span style="color: #000000; font-weight: bold;">else</span> <span style="color: #009900;">&#123;</span>
            Nodo nuevo <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Nodo<span style="color: #009900;">&#40;</span>dato<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            nuevo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
            ultimo.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
            ultimo <span style="color: #339933;">=</span> nuevo<span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #339933;">++;</span>
        <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000000; font-weight: bold;">this</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">//Metodo para borrar al final de la lista.</span>
    <span style="color: #000000; font-weight: bold;">public</span> Nodo deleteLast<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        Nodo eliminar <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>siVacio<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            <span style="color: #003399;">JOptionPane</span>.<span style="color: #006633;">showMessageDialog</span><span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">null</span>, <span style="color: #0000ff;">&quot;La lista se encuentra vacia&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>primero <span style="color: #339933;">==</span> ultimo<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            primero <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
            ultimo <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        <span style="color: #000000; font-weight: bold;">else</span> <span style="color: #009900;">&#123;</span>
            Nodo actual <span style="color: #339933;">=</span> primero<span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">while</span><span style="color: #009900;">&#40;</span>actual.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">!=</span> ultimo<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
                actual <span style="color: #339933;">=</span> actual.<span style="color: #006633;">nodoDer</span><span style="color: #339933;">;</span>
            <span style="color: #009900;">&#125;</span>
            eliminar <span style="color: #339933;">=</span> actual.<span style="color: #006633;">nodoDer</span><span style="color: #339933;">;</span>
            actual.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
&nbsp;
            ultimo <span style="color: #339933;">=</span> actual<span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #339933;">--;</span>
        <span style="color: #000000; font-weight: bold;">return</span> eliminar<span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">//Metodo que imprime el tamaño de la lista.</span>
    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> tamano<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #003399;">JOptionPane</span>.<span style="color: #006633;">showMessageDialog</span><span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">null</span>, <span style="color: #0000ff;">&quot;El tamaño es:<span style="color: #000099; font-weight: bold;">\n</span> &quot;</span> <span style="color: #339933;">+</span> <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">//Metodo que imprime la lista y los valores ingresados.</span>
    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> imprimir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">if</span><span style="color: #009900;">&#40;</span>tamano <span style="color: #339933;">!=</span> <span style="color: #cc66cc;">0</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            Nodo temp <span style="color: #339933;">=</span> primero<span style="color: #339933;">;</span>
            <span style="color: #003399;">String</span> str <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&quot;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">for</span><span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> i <span style="color: #339933;">=</span> <span style="color: #cc66cc;">0</span><span style="color: #339933;">;</span> i <span style="color: #339933;">&lt;</span> <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">tamano</span><span style="color: #339933;">;</span> i<span style="color: #339933;">++</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
                str <span style="color: #339933;">=</span> str <span style="color: #339933;">+</span> temp.<span style="color: #006633;">dato</span> <span style="color: #339933;">+</span> <span style="color: #0000ff;">&quot;<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #339933;">;</span>
                temp <span style="color: #339933;">=</span> temp.<span style="color: #006633;">nodoDer</span><span style="color: #339933;">;</span>
            <span style="color: #009900;">&#125;</span>
            <span style="color: #003399;">JOptionPane</span>.<span style="color: #006633;">showMessageDialog</span><span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">null</span>, str<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Clase Nodo:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">class</span> Nodo <span style="color: #009900;">&#123;</span>
 Nodo nodoDer<span style="color: #339933;">;</span>
 <span style="color: #000066; font-weight: bold;">int</span>  dato<span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">public</span>  Nodo<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> dato<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">dato</span> <span style="color: #339933;">=</span> dato<span style="color: #339933;">;</span>
 <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">nodoDer</span> <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
 <span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.mixinformatico.com/2010/03/25/estructura-de-datos-java-listas-simplemente-enlazadas/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- Dynamic Page Served (once) in 0.606 seconds -->

