UNIDAD 3: ARREGLOS

C# POCKET PDA 4: ARREGLOS TIPO TABLA


Un arreglo tipo tabla se define como un conjunto de datos del mismo tipo organizados en dos o mas columnas y uno o mas renglones.

Para procesar ( recordar solo operaciones y comparaciones) internamente todos los elementos de la tabla se ocupan dos ciclos for(), uno externo para controlar renglón y uno interno para controlar columna.

Los elementos de la tabla se deberan simbolizar con el nombre de la tabla y 2 subindices, el primer subindice referencia al renglon y el siguiente subindice referencia la columna los dos dentro del mismo corchete.

La declaración de una tabla sera de acuerdo al siguiente formato:

Public static tipodato[,] nomtabla=new tipodato[cant reng, cantcol];

Ej: public static float[,] sueldos=new float[5,8];

Para capturar sus elementos, usaremos un textbox y un boton de captura, solo tener cuidado o mucho control sobre los indices ren y col como lo muestra el ejemplo.

Para efectuar otros procesos tales como operaciones, despliegue con todos los elementos de la tabla se deberan usar 2 ciclos, un for externo para controlar renglon y un for interno para controlar columna.

Prog12.aspx

// inicializando objetos mobiles
// y definiendo lenguaje a usar por servidor
<%@ Page Inherits="System.Web.UI.MobileControls.MobilePage"
Language=CS%>
<%@ Register TagPrefix="mobile"
Namespace="System.Web.UI.MobileControls"
Assembly="System.Web.Mobile"%>
// todos los controles ponerlos dentro de una forma
<mobile:Form runat=server>
Ren<mobile:TEXTBOX ID=REN SIZE=2 TEXT=0 RUNAT=SERVER/>
Col<mobile:TEXTBOX ID=COL SIZE=2 TEXT=0 RUNAT=SERVER/><BR>
DAME CALIF<MOBILE:TEXTBOX ID=CALIF SIZE=10 RUNAT=SERVER/>
<mobile:COMMAND TEXT=CARGAR ONCLICK=CARGAR RUNAT=SERVER/><BR>
<mobile:COMMAND TEXT=PROCESAR ONCLICK=PROCESO RUNAT=SERVER/><BR>
</mobile:Form>
<SCRIPT RUNAT=SERVER>
static int[,] calif= new int[2,3];
void CARGAR(Object sender, EventArgs e)
{
int reng=System.Int32.Parse(REN.Text);
int col=System.Int32.Parse(COL.Text);
calif[reng,col]=System.Int32.Parse(CALIF.Text);
col++;
CALIF.Text=" ";
if (col==3){reng++; col=0;};
if (reng==2){CALIF.Text="TABLA LLENA";};
REN.Text=reng.ToString();
COL.Text=col.ToString();
}
void PROCESO(Object sender, EventArgs e)
{
// procesando y regalando 10 puntos a la calificacion
for(int reng=0; reng <= 1; reng++)
for(int col=0; col <=2; col++)
{calif[reng,col]=calif[reng,col] +10;};
// desplegando usando ado viejo
for( int reng=0; reng <= 1; reng++)
{for(int col=0; col<=2; col++)
{Response.Write(calif[reng,col]+"..");};
Response.Write("<br>");};
}
</SCRIPT>

Notas:

Observar el formato de declaración y como se controlan los indices de captura reng, col.

Para procesar los elementos se usan dos ciclos for y el formato tabla [reng,col].

Recordar que un programa en NET es un conjunto de objetos de diferente fuente interactuando entre si, en este problema se uso el objeto RESPONSE y su metodo WRITE, este RESPONSE es un objeto que proviene de ASP(ACTIVE SERVER PAGES).

Observar que no se ocupo al final poner en cero las variables de control (reng, col) porque:

a) Se estan al principio cargando de las cajas de texto ren,col

b) Estas cajas de texto si se pusierón en 0(cero) en una de las intrucciones if.

ASP es una libreria de objetos hecha por Microsoft y contiene siete objetos muy utiles para el trabajo con paginas html, consultar el apendice al final de esta unidad donde se incluye el apendice ASP.

Corrida prog11.aspx

image494.jpg

TAREAS PROGRAMACION C# PDA PROGRAMACION C# PDA

1.- CONSTRUIR UN CUADRO QUE CONTENGA LOS COSTOS FIJOS DE CUATRO PRODUCTOS CUALESQUIERA, QUE SE PRODUCEN EN TRES PLANTAS DIFERENTES DE UNA EMPRESA MAQUILADORA

2.- CONSTRUIR UN CUADRO QUE CONTENGA LOS INGRESOS MENSUALES POR VENTAS DURANTE LOS TRES PRIMEROS MESES DEL AÑO DE CUATRO SUCURSALES DE UNA CADENA DE AUTO REFACCIONES, AGREGAR AL FINAL UNA LISTA QUE MUESTRE LOS INGRESOS MENSUALES TOTALES POR MESES Y UNA SEGUNDA LISTA QUE MUESTRE LOS INGRESOS MENSUALES TOTALES POR SUCURSAL

3.-CONSTRUIR UN CUADRO QUE CONTENGA LAS COMISIONES GANADAS POR TRES VENDEDORES, DE LOS 5 TIPOS DE LINEA BLANCA DE CONOCIDA MUEBLERIA, ADEMAS LISTAS DE COMISIONES TOTALES Y PROMEDIOS GANADAS POR LOS VENDEDORES, ASI COMO LISTAS DE COMISIONES TOTALES Y PROMEDIOS POR TIPO DE LINEA BLANCA

ESTUDIAR ESTE CODIGO:

' PARA TOTALES Y PROMEDIOS POR RENGLON
FOR R = 0 TO 3
FOR C = 0 TO 2
TOTRENG(R) = TOTRENG(R) + TABLA(R,C)
NEXT C
PROMRENG(R) = TOTRENG(R)/3
NEXT R
'PARA TOTALES Y PROMEDIOS POR COLUMNA
FOR C = 0 TO 2
FOR R = 0 TO 3
TOTCOL(C)=TOTCOL(C) + TABLA(R,C)
NEXT R
PROMCOL(C) = TOTCOL(C) / 4
NEXT C

SUGERENCIA: CONSTRUIR PRIMERO LOS CUADROS EN PAPEL.

Politica de Privacidad