Quick Sort

¿Has encontrado un error? ¿Tienes la solución? Deja tu correción ;-)

Antes de comentar: Gran parte de los ejercicios propuestos no tienen librerías debido a que Wordpress las eliminó al verlas como etiquetas HTML. Si sabes/tienes/conoces las librerías que hacen falta, déjalo en los comentarios. Y lo mas importante: Todos los ejemplos fueron realizados por estudiante con únicamente conocimiento básico del lenguaje, no de programación.

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
80
81
82
83
84
85
86
87
88
89
90
91
92
program qsort;
uses
    crt;
const
     n=10;type
    vec=array[1..n]of integer;
var
   v:vec;
   c:integer; 
procedure quickredit(ini,fin:integer; var pos:integer);
var
   izq,der,aux:integer;
   band:boolean;begin
     izq:=ini;
     der:=fin;
     pos:=ini;
     band:=true;     while band=true do
     begin
          while (v[pos]<=v[der]) and (pos<>der) do
                der:=der-1;
          if pos=der then             band:=false
          else
              begin
                   aux:=v[pos];
                   v[pos]:=v[der];                   v[der]:=aux;
                   pos:=der;
                   while (v[pos]>=v[izq]) and (pos<>izq) do
                         izq:=izq+1;
                   if pos=izq then                      band:=false
                   else
                       begin
                            aux:=v[pos];
                            v[pos]:=v[izq];                            v[izq]:=aux;
                            pos:=izq;
                       end;
              end;
     end;{while}end;
 
procedure quickit (v:vec; n:integer);
var
   top,ini,fin,pos:integer;   pmay,pmen:vec;
begin
     top:=1;
     pmen[top]:=1;
     pmay[top]:=n;     while top>0 do
     begin
          ini:=pmen[top];
          fin:=pmay[top];
          top:=top-1;          quickredit(ini,fin,pos);
          if ini<(pos-1) then
          begin
               top:=top+1;
               pmen[top]:=ini;               pmay[top]:=pos-1;
          end;
          if fin>(pos+1) then
          begin
               top:=top+1;               pmen[top]:=pos+1;
               pmay[top]:=fin;
          end;
     end;{while}
end; 
begin
     clrscr;
     for c:=1 to n do
     begin          write('Dame un numero: ');
          readln(v[c]);
     end;
     quickit(v,n);
     writeln;     writeln('Vector acomodado: ');
     for c:=1 to n do
     begin
          write(v[c],' ');
     end;     readkey;
end.

Punto importante: Si vas a sugerir un segmento de código en algún lenguaje debes hacerlo así:

  • Si es lenguaje C <code lang="c">Código en C</code>
  • Si es lenguaje Pascal <code lang="pascal">Aquí dentro el código de Pascal</code>.

De esta manera el código coloreas el código.

Deja un comentario

Suscribirse a los comentarios.