universidad técnica de ambato
DESCRIPTION
VECTORES Y MATRICESTRANSCRIPT
UNIVERSIDAD
TÉCNICA DE AMBATO
FACULTAD DE CIENCIAS
HUMANAS Y DE LA EDUCACIÓN
CARRERA DE dOCENCIA
iNFORMÁTICA
VECTORES Y MATRICES
ALUMNO: DIEGO RODRIGO JURADO ORTUÑO
TUTORA: MSC. ING. WILMA GAVILANEZ
MODULO PROGRAMACIÓN
SEMESTRE: TERCER SEMESTRE
VECTOR
Un vector, también llamado ARRAY (ARREGLO) unidimensional, es una estructura de datos que permite agrupar elementos del mismo tipo y almacenarlos en un solo bloque de memoria juntos, uno despues de otro.
A este grupo de elementos se les identifica por un mismo nombre y la posición en la que se encuentran. La primera posición del array es la posición 0.
SINTAXIS
Podríamos agrupar en un array una serie de elementos de tipo enteros, flotantes, caracteres, objetos, etc. Crear un vector en c++ es sencillo, seguimos la siguiente sintaxix:
Tipo nombre[tamaño]; Aula[25]; int a[5];//Vector de 5 enteros float b[5];//vector de 5 flotantes
Podríamos también inicializar el vector en la declaración:
int a[] = {5,15,20,25,30};
float b[] = {10.5,20.5,30.5,12.5,50.5};
Producto product[] =
{celular,calculadora,camara,ipod,usb};
Matrices Una matriz es un vector de vectores o un
también llamado array bidimensional. La manera de declarar una matriz es c++ es similar a un vector:
ver fuenteImprimir? int matriz[filas][colns];
int es el tipo de dato, matriz es el nombre del todo el conjunto de datos y debo de especificar el numero de filas y columnas. Las matrices también pueden ser de distintos tipos de datos como char, float, double, etc.
Las matrices en c++ se almacenan al igual que los vectores en posiciones consecutivas de memoria. Usualmente uno se hace la idea que una matriz es como un tablero. Pero internamente el manejo es como su definicion lo indica, un vector de vectores, es decir, los vectores estan uno detras del otro juntos.
La forma de acceder a los elementos de la matriz es utilizando su nombre e indicando los 2 subindices que van en los corchetes. Si Coloco int matriz[2][3]=10; //estoy asignando al cuarto elemento de la tercera fila el valor 10. No olvidar que tanto filas como columnas se enumeran a partir de 0.
Bueno y para recorrer una matriz podemos usar igualmente un bucle. En este caso 2 for:
for(int i=0;i<filas;i++){for(int j=0;j<colns;j++){matriz[i][j] = i % j;}}
Punteros
PUNTEROSEl valor de todas las variales que manejamos en nuestros programas se almacenan en memoria y tienen una dirección. Un puntero es una variable especial que apunta a la dirección de memoria de una variable. El puntero tiene a su vez su propia dirección. Todas estas direcciones tienen un formato hexadecimal.
Los punteros son herramientas muy poderosas con muchas utilidades y enormes ventajas como veremos más adelante. A grandes rasgos, un puntero me permite desplazarme en la memoria, apuntar, re direccionar a ciertas variables, funciones, métodos, objetos sin necesidad de mover grandes bloques de datos, lo cual nos ahorra muchísimo el consumo de memoria en los programas.
Puntero
Un puntero se debe declarar de acuerdo al tipo de dato al que apunta. Ejem:
int *var; //Un puntero llamado var que podrá apuntar a cualquier variable de tipo entero.
char *u;//puntero de tipo char Persona *per;//puntero de tipo persona
EJERCICIOS…
EJERCICIO 1
Diseñe un programa que me permita generar la serie de fibonaci
//Matriz que genera la serie del fibonacci#include<conio.h>#include<stdio.h>int i,j, N, vec1[10], mat[10][10];int main(){ int a=0, b=0, c=0, k; a=-1; b=1; clrscr(); gotoxy(2,2);cprintf("Ingrese el tamanio de la matriz: "); scanf("%d",&N); //mat[0][0] = c; // Ingreso de datos a la matriz for(i=0; i<N; i++) { k = 0; for(j=0; j<N; j++, k+=4) { c = a+b; a = b; b = c; mat[i][j] = c; gotoxy(5+k, 4+i); printf("%d", mat[i][j]); } }
getch();return 0;}
Sin errores
Ingresamos el tamaño de la matriz
EJERCICIO 2
DISEÑE UN PROGRAMA PARA
INGRESAR DATOS CON
ESTRUCTURAS DE DATOS
#include<stdio.h>#include<conio.h>#include<stdlib.h>struct datos1{char cedula[15];char nombres[15];char apellidos[15];int edad;}datos[10]; void borde() { int i; for(i=2;i<=78;i++) { gotoxy(i,2);printf("*"); gotoxy(i,24);printf("*"); } for(i=2;i<=24;i++) { gotoxy(2,i);printf("*"); gotoxy(78,i);printf("*"); }} void main() { int edad ,op,i,n,fila; do{ clrscr(); borde();
gotoxy(10,3);printf("PROGRAMA PARA INGRESAR DATOS CON ESTRUCTURAS DE DATOS"); gotoxy(8,4);printf("Ingrese el numero de ingresos:");scanf("%d",&n); fila=7; for(i=1;i<=n;i++) { flushall(); gotoxy(8,5);printf("CEDULA NOMBRES APELLIDOS EDAD"); gotoxy(8,fila);gets(datos[i].cedula);gotoxy(25,fila);gets(datos[i].nombres);gotoxy(40,fila);gets(datos[i].apellidos);gotoxy(60,fila);scanf("%d",& edad);fila=fila+1;}gotoxy(30,13);printf("SALIDA DE DATOS");fila=14;for(i=1;i<=n;i++){gotoxy(8,fila);puts(datos[i].cedula);gotoxy(25,fila);puts(datos[i].nombres);gotoxy(40,fila);puts(datos[i].apellidos);gotoxy(60,fila);printf("%d", edad);fila=fila+1;}gotoxy(10,22);printf("Ingrese 1para continuar y 0 para salir:");scanf("%d",&op);}while(op==1);getch();}
Compilamos el programa
EJECUTAMOS EL PROGRAMA
EJERCICIO 2
DISEÑE UN PROGRAMA QUE ME PERMITA FORMAR UNA MATRIZ EN X
#include<stdio.h>#include<conio.h>void main(){int i,j,col,fila,lim,op,a,x;int matriz1[10][10];do{clrscr();for(i=3;i<=80;i++){gotoxy(i,3);printf("*");gotoxy(i,50);printf("*");}for(i=3;i<=50;i++){gotoxy(3,i);printf("*");gotoxy(80,i);printf("*");}col=8;fila=8;gotoxy(20,3);printf("PROGRAMA PARA FORMAR UNA MATRIS EN
X");gotoxy(10,5);printf("Ingrese el limite:");scanf("%d",&lim);gotoxy(10,7);printf("ENTRADA SALIDA DIAGONAL
");for(i=1;i<=lim;i++){for(j=1;j<=lim;j++){gotoxy(col,fila);scanf("%d",&matriz1[i][j]);col=col+2;}fila=fila+1;col=8;}col=25;fila=8;
for(i=1;i<=lim;i++){for(j=1;j<=lim;j++){col=col+2;gotoxy(col,fila);printf("%d",matriz1[i][j]);}fila=fila+1;col=25;}col=50;fila=8;for(i=1;i<=lim;i++){for(j=1;j<=lim;j++){if(i==j){gotoxy(col,fila);printf("%d",matriz1[i][j]);col=col+5;fila=fila+1;}for(a=1;a<=lim;a++){gotoxy(col,fila);printf("%d",matriz1[a][x]);x=lim-1;
}}}gotoxy(10,45);printf("INGRESE 1 PARA CONTINUAR Y 0 PARA SALIR");scanf("%d",&op);}while(op==1);getch();}
Compilamos el programa
EJECUTAMOS EL PROGRAMA
EJERCICIO 3
DISEÑE UN PROGRAMA QUE ME PERMITA REALIZAR EL PRODUCTO DE UNA MATRIZ
#include<stdio.h>#include<conio.h>int lim,col,col1,col2,fila,fila1,fila2,h,i,j,op,a;int matriz1[20][20],matriz2[20]
[20],matriz3[20][20];void borde(){for(i=2;i<=25;i++){gotoxy(2,i);printf("*");gotoxy(78,i);printf("*");}for(i=2;i<=78;i++){gotoxy(i,2);printf("*");gotoxy(i,25);printf("*");}}void ingreso(){col=5;fila=10;for(i=1;i<=lim;i++){ for(j=1;j<=lim;j++) { gotoxy(col,fila);scanf("%d",&matriz1[i][j]); col=col+5; }
col=5;fila=fila+1;}col1=25;fila1=10;for(i=1;i<=lim;i++){ for(j=1;j<=lim;j++) {
gotoxy(col1,fila1);scanf("%d",&matriz2[i][j]); col1=col1+5; }col1=25;fila1=fila1+1;}}void producto(){col2=42;fila2=10;for(i=0;i<=lim;i++){for(j=0;j<=lim;j++){matriz3[i][j]=0;for(h=0;h<=lim;h++){matriz3[i][j]=matriz3[i][j]+matriz1[i][h]*matriz2[h][j];}}
}for(i=1;i<=lim;i++){for(h=1;h<=lim;h++){gotoxy(col2,fila2);printf("%d",matriz3[i][h]);col2=col2+4;}col2=42;fila2=fila2+1;}}void main(){do{clrscr();borde();gotoxy(20,3);printf("PRODUCTO ALGEBRAICO DE UNA MATRIZ");gotoxy(7,5);printf("Ingrese el limite: ");scanf("%d",&lim);gotoxy(5,7);printf("MATRIZ_1");gotoxy(25,7);printf("MATRIZ_2");gotoxy(40,7);printf("PRODUCTO");ingreso();producto();gotoxy(8,22);printf("Ingrese 1 para continuar y 0 para salir:");scanf("%d",&op);}while(op==1);getch();
}
Compilamos el programa
EJECUTAMOS EL PROGRAMA
EJERCICIO 4
#include<conio.h>#include<stdio.h>void main(){int ma[50][50],vc[50],q,y,n,l,a,va,i,j,k,x,c,f;clrscr(); textcolor(6);gotoxy (10,6); cprintf("INGRESE
UN LIMITE "); scanf("%d",&n);f=7;va=0;c=10;for (i=1;i<=n;i++){
c=c+3;for (j=1;j<=n;j++){
f=f+2;va=va+5;ma[i][j]=va;gotoxy(c,f);printf("%d",ma[i][j]);
}
f=7;}/*principal*/
c=10;f=19;for(i=1;i<=n;i++)
{c=c+3;for(j=1;j<=n;j++) {
f=f+1;if(i==j)
{
} } f=19;}
/*secundaria*/ k=n; a=2;
for (i=1;i<=n;i++){a=a+2; textcolor(13);gotoxy(10+a,32-i);cprintf("%d",ma[i][k]); vc[i]=ma[i][k];k=k-1;} y=7; for (x=1;x<=q;x++){ y=y+1; gotoxy(48,y);cprintf("%d",vc[x]);}
}/*----------------------------------*/f=7;va=0;
c=30;for (i=1;i<=n;i++){
c=c+3;for (j=1;j<=n;j++){
f=f+2;va=va+7;ma[i][j]=va;gotoxy(c,f);printf("%d",ma[i][j]);
}
f=7;}/*primaria2*/
c=30;f=19;
for(i=1;i<=n;i++){
c=c+3;for(j=1;j<=n;j++){
f=f+1;
if(i==j){ textcolor(10);
gotoxy(c,f);cprintf("%d",ma[i][j]); vc[i]=ma[i][j];
} }
f=19;}
/*secundaria2*/k=n;for (i=1;i<=n;i++){
textcolor(13);gotoxy(35+i,32-i);cprintf("%d",ma[i][k]);
vc[i]=ma[i][k];
k=k-1;} q=n*4;/* y=7;for (x=1;x<=q;x++){ y=y+1; gotoxy(48,y);cprintf("%d",vc[x]);}*/
getch();
Compilamos el programa
EJECUTAMOS EL PROGRAMA
EJERCICIO 5
PROGRAMA PARA REALIZAR OPERACIONES CON VECTORES (PRUEBA 1)
# include<stdio.h>#include<conio.h>void main(){int v1[20], v2[20], v3[20], v4[20], i , lim, par, impar,col,fil;clrscr();gotoxy(25,4);printf("OPERACIONES ENTRE VECTORES");gotoxy(10,6);printf("INGRESE EL LIMITE ==> : ");scanf("%d",
&lim);do { gotoxy(25,8); printf(" "); gotoxy(10,8);printf("INGRESE EL NUMERO PAR ==> : ");
scanf("%d",&par); } while(par % 2==1);do { gotoxy(25,10); printf(" "); gotoxy(10,10);printf("INGRESE EL NUMERO IMPAR ==> : ");
scanf("%d",&impar); } while(impar % 2==0);col=15;fil=20;for(i=1;i<=lim;i++){v1[i]=par*i;gotoxy(14,15);printf("V1");gotoxy(col,fil);printf("%d",v1[i]);fil=fil+1;}
fil=20;for(i=1;i<=lim;i++){v2[i]=impar*i;gotoxy(20,15);printf("V2");gotoxy(col+5,fil);printf("%d",v2[i]);fil=fil+1;}
fil=20;for(i=1;i<=lim;i++){v3[i]=v1[i]*v2[i];gotoxy(25,15);printf("V3");gotoxy(col+10,fil);printf("%d",v3[i]);fil=fil+1;}
fil=20;for(i=lim;i>0;i--){ v3[i]=v1[i]*v2[i];gotoxy(38,15);printf("V4");gotoxy(col+20,fil);printf("%d",v3[i]);fil=fil+1;
}
getch();}
Compilamos el programa
EJECUTAMOS EL PROGRAMA
EJERCICIO 6
EXAMEN
Diseñe un programa utilizando Matrices y Funciones que permita:
1. Ingresar n elementos en una matriz con datos entre 5 y 35, excluyendo las diagonales
2. principal y secundaria, en dónde la diagonal principal se llena con la serie del Fibonnaci
3. y la diagonal secundaria con el factorial de los números ascendentes iniciando en 3.
4. Recorra la matriz y guarde los datos de la diagonal principal en las posiciones pares del vector
5. y los datos de la diagonal segundaria en las posiciones impares del vector.
6. Presente como resultado el vector origen resultante y el mismo vector preséntelo impreso en forma descendente
Compilamos el programa
EJECUTAMOS EL PROGRAMA
GRACIAS
POR SU ATENCIÓN