09.05.2013 Views

Algoritmos y Programación en Pascal

Algoritmos y Programación en Pascal

Algoritmos y Programación en Pascal

SHOW MORE
SHOW LESS

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

A.2. Variables aleatorias 487<br />

al lector interesado a los ejercicios, donde se indican otras, y a los com<strong>en</strong>tarios<br />

bibliográficos.<br />

Como ejemplo inicial, considérese que un supermercado desea hacer un sorteo<br />

<strong>en</strong>tre sus cli<strong>en</strong>tes, de forma que sus probabilidades de ser premiados sean proporcionales<br />

al dinero gastado <strong>en</strong> la ti<strong>en</strong>da. Trivialm<strong>en</strong>te se ve que esta situación<br />

es un caso particular del dado trucado, explicado al final del apartado anterior,<br />

por lo que no requiere mayor explicación (véase el ejercicio 15).<br />

Un ejemplo típico es el acto de barajar, que consiste s<strong>en</strong>cillam<strong>en</strong>te <strong>en</strong><br />

Dado un array A de n elem<strong>en</strong>tos,<br />

Situar <strong>en</strong> A1 uno cualquiera,<br />

escogido aleatoriam<strong>en</strong>te <strong>en</strong>tre A1 y An.<br />

...<br />

Situar <strong>en</strong> An−1 uno cualquiera,<br />

escogido aleatoriam<strong>en</strong>te <strong>en</strong>tre An−1 y An.<br />

donde la elección <strong>en</strong>tre Aizda y Adcha se efectúa mediante la asignación<br />

posic:= variable aleatoria uniforme del conjunto {izda, . . . , dcha}<br />

referida <strong>en</strong> el apartado A.2.1 y <strong>en</strong> el ejercicio 12c de este capítulo.<br />

Finalm<strong>en</strong>te, esbozamos el método del acontecimi<strong>en</strong>to crítico, para simular<br />

una cola (una v<strong>en</strong>tanilla de un banco, por ejemplo), donde llega un cli<strong>en</strong>te cada λ1<br />

unidades de tiempo y tarda <strong>en</strong> ser at<strong>en</strong>dido λ2 unidades de tiempo, por término<br />

medio. 6<br />

Un paso intermedio del diseño de este programa puede ser el sigui<strong>en</strong>te:<br />

{Dar valores iniciales a los datos}<br />

reloj:= 0;<br />

longCola:= 0;<br />

sigLlegada:= 0; {tiempo hasta la sigui<strong>en</strong>te llegada}<br />

sigSalida:= 0; {tiempo hasta la sigui<strong>en</strong>te salida}<br />

repetir sin parar<br />

if cola vacía o sigLlegada < sigSalida th<strong>en</strong> begin<br />

{llegada de cli<strong>en</strong>te}<br />

reloj:= reloj + sigLlegada;<br />

sigSalida:= sigSalida - sigLlegada;<br />

sigLlegada:= ExpNeg(λ1);<br />

longCola:= longCola + 1;<br />

EscribirSituacion(reloj, longCola)<br />

<strong>en</strong>d {th<strong>en</strong>}<br />

else begin<br />

{salida de cli<strong>en</strong>te}<br />

6 El tiempo <strong>en</strong>tre llegadas (resp. salidas) es una variable aleatoria expon<strong>en</strong>cial negativa de<br />

parámetro λ1 que se supone desarrollada, ExpNeg(lambda) (véase el ejercicio 14).

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!