Ir al contenido principal

Programacion: Arreglos con estructuras - ordenamientos

1.- Se pide realizar un ordenamiento de artículos, para ello se debe ingresar n artículos y ordenarlos por su monto de inversión.

struct articulo
{char codigo[10];
 char producto[20];
 float preciocompra;
 float monto;
 int cantidad;
 }


#include<iostream.h>
#include<string.h>
#include<conio.h>
#define MAX 50
struct articulo
{char codigo[10];
 char producto[20];
 float preciocompra;
 float monto;
 int cantidad;
 };
 void leer(int, struct articulo[]);
 void montodeinversion(int, struct articulo[]);
 void ordenmonto(int, struct articulo[]);
 void listado(int, struct articulo[]);
 void main()
 {int n;
  struct articulo Art[MAX];
  cout<<"Cantidad de articulos que desea poner:";
  cin>>n;
  leer(n,Art);
  montodeinversion(n,Art);
  ordenmonto(n,Art);
  cout<<"productos ordenados por su cantidad de monto mayor:"<<endl;
  listado(n,Art);
  getch();
  }
  void leer(int n, struct articulo x[])
  {int i;
   for(i=0;i<n;i++)
   {cout<<"codigo:"; cin>>x[i].codigo;
    cout<<"producto:"; cin>>x[i].producto;
    cout<<"precio:"; cin>>x[i].preciocompra;
    cout<<"cantidad:"; cin>>x[i].cantidad;
    }
    getch();
  }
  void montodeinversion(int n, struct articulo x[])
  {int i;
  for(i=0;i<n;i++)
  x[i].monto=x[i].preciocompra*x[i].cantidad;
  getch();
  }

  void ordenmonto(int n, struct articulo x[])
  {int i,j;
   struct articulo temp;
   for(i=0;i<n;i++)
    for(j=n-1;j>i;j--)
     if((x[j-1].monto,x[j].monto)>0)
     {temp=x[j-1];
      x[j-1]=x[j];
      x[j]=temp;
      }
      getch();
  }

  void listado(int n, struct articulo x[])
  {int i;
   for(i=0;i<n;i++)
   {cout<<x[i].codigo<<"\t";
    cout<<x[i].producto<<"\t";
    cout<<x[i].monto<<endl;
    }
    getch();
  }



Comentarios

Entradas más populares de este blog

Mostrar y Modificar una tabla en Netbeans

Continuando con el ejercicio anterior, ahora veremos como modificar una tabla creada en SLQ Server  desde Netbeans. Para ello sólo adicionaremos algunos códigos, en este caso siguiendo con el ejercicio anterior sólo agregamos en el index.jsp lo siguiente: <td align="center"><a href ="frmProductos.jsp?txtpara=M&txtid = <%= objpro.getcodigo() %>"><img src="images/upd.gif"></a></td> En el java class Productos, aparte de crear el método mostrar, crearemos dos métodos más: Método para Buscar y para Modificar, pero primero antes de todo declaramos nuestras variables como privado, creamos un constructor y luego aplicamos un Getter and Setter como se muestra en las siguientes imágenes:   Después de haber hecho el paso anterior, creamos un nuevo jsp la cual llamaremos frmProductos y escribimos la siguiente codificación: Luego creamos otro package que llamaremos Servlet, dentr...

Programación en c++ : Arreglos - Ordenar elementos y eliminar repetidos

1.- Hacer un programa usando arreglos, que nos permita ingresar n cantidad de elementos, luego nos deberá mostrar una lista ordenada de los elementos. Si en la lista se repiten algunos números, hacer que nos muestre una nueva lista sin los números repetidos.  #include<iostream.h> #include<conio.h> #define MAX 50 void leer(int,int[]); void ordenar(int, int[]); void listaordenar(int,int[]); void main() {int n, x[MAX],j,k,i;  cout<<"Ingresar limite:";  cin>>n;  leer(n,x);  ordenar(n,x);  cout<<"La lista ordenada es:"<<endl;  listaordenar(n,x);  cout<<"Presione cualquier tecla para eliminar...."<<endl;  getch();  for(i=0;i<n;i++)   for(j=i+1;j<n;j++)    if(x[i]==x[j])    {for(k=j;k<n-1;k++)     x[k]=x[k+1];     n=n-1;     j=i;    }  cout<<endl<<"La nueva li...

Programación en c++ : Matriz - Calcular mayor de la matriz

1.- Hacer un programa que permita ingresar n datos de una matriz y calcular el mayor de la matriz. #include<iostream.h> #include<conio.h> #define lim 50 void main() {int i,j,a[lim][lim],fila,col,  may=a[0][0];  clrscr(); do {cout<<"Ingresar limite de la fila:";  cin>>fila; }while(fila<=0); do {cout<<"Ingesar limite de la columna:";  cin>>col; }while(col<=0); gotoxy(10,7); cout<<"Ingresar Elementos de la matriz\n\n"; for(i=0;i<fila;i++) for(j=0;j<col;j++) {cout<<"a["<<i<<"]"<<"["<<j<<"]";  cin>>a[i][j]; } for(i=0;i<fila;i++) for(j=0;j<col;j++) if(a[i][j]>may) may=a[i][j]; clrscr(); gotoxy(10,7); cout<<"Elementos de la matriz\n\n"; for(i=0;i<fila;i++) for(j=0;j<col;j++) {cout<<a[i][j];  cout<<"\n"; } clrscr(); gotoxy(10,20); cout...