Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - BJM

#31
Programación C/C++ / Instruccion if
22 Octubre 2012, 13:58 PM
Este codigo debe buscar el numero mayor de un array de punteros mostrar su valor y posicion, pero en la instruccion IF me da error

#include<stdio.h>
#include<stdlib.h>

int main()
{
  int *array[10];
 
  for(int i=0; i<10; i++)
  {
    printf(" \n Ingrese valor de array[%d]:  ",i); scanf("%d", (array+i));
  }

  int may=0, pos = 0;
  for(int i=0; i<10; i++)
    if (*(array+i) > may)
    {
      may = *(array+i);
      pos = i;
    }
   
for(int i=0; i<10; i++)
  {
    printf(" \n valor posicion array[%d]= %d ", i, *(array+i));
  }
 
  printf(" \n El valor mayor es: %d , en la pos array[i]", may, pos);
  printf("\n\n);
  system("pause");
}

#32
El siguiente codigo se encarga de buscar el numero mayor de un array de enteros, luego al final cuando se muestra la posicion de origen donde se ubico ese valor, no es el correcto, y aqui el codigo:

Código (cpp) [Seleccionar]
#include<stdio.h>           
#include<stdlib.h>
#include<iostream>
using namespace std;

main(){
       int tem=0,may=0,pos=0,i,j,array[9];
        for(i=0;i<10;i++){
        cout<<"\n ingrese valor de array["<<i<<"]= ";
        cin>>*(array+i);
        }
        for(i=0;i<9;i++){
         for(j=i+1;j<10;j++){
          if(*(array+i)>*(array+j)){
              pos=i;                     
           tem=*(array+i);           /*intercambio*/
           *(array+i)=*(array+j);                       
          *(array+j)=tem;
          may=tem;                         /* asignacion */
          }
          else
          pos=j;
          may=*(array+j);
         
           }
             }
          cout<<"\n Valor mayor= "<<may<<" En la posicion array["<<pos<<"]";
         
          cout<<"\n\n";
          system("pause");
          }
#33
Si tendre que reforzar la base, ahora estoy probando otra manera de manipular los punteros en este caso, si tengo:

struct{ int linea1;
           int linea2;
           int linea3;
           int linea4;
           int linea5;
          }turno1,turno2,turno3,*pt;



pt=&turno1;
pt=&turno2;
pt=&turno3;


Es decir:

struct{ int miembro1;
          int miembro2;
          int miembro n;
         }variable1, variable2, variable n,*pt;

Es necesario asignarle la direccion de cada variable a pt ?

pt=&variable1;
pt=&variable2;
pt=&variable n;


;D



#34
Gracias avesudra, tenia en cuenta que faltaba los prototipos de funciones, el codigo no lo he terminado, tambien para la proxima omitire las mayusculas, la mayoria no lo utiliza, ahora tengo una nueva duda en la linea 20, el compilador indica :
variable or field `ingreso' declared void

Código (cpp) [Seleccionar]
#include<stdio.h>           
#include<stdlib.h>
#include<iostream>
using namespace std;


struct { char asignatura1;
         char asignatura2;
         char asignatura3;
         char asignatura4;
         char asignatura5;
         } seccion1,seccion2,seccion3;
         
         struct { struct seccion1;
                  struct seccion2;
                  struct seccion3;
                  } secciones, *pt=&secciones;
         
int menu(int opc);
void ingreso(struct *,int *);

main(){
       
       struct *pt;
       int opc,n,*cat;
       
       
       pt=(secciones*)malloc(sizeof(secciones));
       
       switch (menu(opc)){
       case 1:
       ingreso(pt->secciones.seccion1,&n=5);
       break;
       case 2:
       ingreso(pt->secciones.seccion2,&n=4);
       break;
       case 3:
       ingreso(pt->secciones.seccion3,&n=2);
       break;
       case 4:
       break;
       default:
       cout<<"\n OPCION INVALIDA";
       break;
       }
       
       system("pause");
       }
       
       int menu(int opc){
       cout<<"\n MENU \n";
       cout<<"1..Ingreso sección 1 (5 materias)\n";
       cout<<"2..Ingreso sección 2 (4 materias)\n";
       cout<<"3..Ingreso sección 3 (2 materias)\n";
       cout<<"4..salir\n";
       cin>>opc;
       return(opc);
       }
       
void ingreso(struct pt->secciones.seccion1,int *cat){
do{
if(*cat>0){
cout<<"\n Ingrese asignatura 1: "; cin>>pt->secciones.seccion1.asignatura1;
cout<<"\n Ingrese asignatura 2: "; cin>>pt->secciones.seccion1.asignatura2;
}
if(*cat>2){
cout<<"\n Ingrese asignatura 3: "; cin>>pt->secciones.seccion2.asignatura3;
cout<<"\n Ingrese asignatura 4: "; cin>>pt->secciones.seccion2.asignatura4;
}
if((*cat>4)&&(*cat<=5)){
cout<<"\n Ingrese asignatura 5: "; cin>>pt->secciones.seccion1.asignatura5;
}
}while(*cat<=5);
}
#35
Este programa no esta terminado solo quiero que me aclaren si al acceder a cada struct en este caso seccion1, seccion2, seccion3, debo declarar un puntero por cada struct o puedo utilizar un puntero general supongamos *pt?

struct { struct seccion1;
         struct seccion2;
         struct seccion3;
         } secciones, *p1=&secciones,*p2=secciones,*p3=secciones;
         
struct { char asignatura1;
         char asignatura2;
         char asignatura3;
         char asignatura4;
         char asignatura5;
         } seccion1,seccion2,seccion3,

main(){
       
       struct *p1,*p2,*p3,*cat;
       int opc,n;
       
       p1=(secciones*)malloc(sizeof(secciones));
       p2=(secciones*)malloc(sizeof(secciones));
       p3=(secciones*)malloc(sizeof(secciones));
     
int menu(){
       cout<<"\n MENU \n";
       cout<<"1..Ingreso sección 1 (5 materias)\n";
       cout<<"2..Ingreso sección 2 (4 materias)\n";
       cout<<"3..Ingreso sección 3 (2 materias)\n";
       cout<<"4..Volver al menu \n";
       cout<<"5..salir\n";
       cin>>opc;
       return(opc);
       }
       
       switch (menu()):
       case 1:
       ingreso(p1->secciones.seccion1,&n=5);
       break;
       case 2:
       ingreso(p2->secciones.seccion2,&n=4);
       break;
       case 3:
       ingreso(p3->secciones.seccion3,&n=2);
       break;
       case 4:
       menu();
       break;
       default:
       break;
       }
       
void ingreso(struct p1->secciones.seccion1,int *cat){

if(*cat>0){
cout<<"\n Ingrese asignatura 1: "; cin>>p1->secciones.seccion1.asignatura1;
cout<<"\n Ingrese asignatura 2: "; cin>>p1->secciones.seccion1.asignatura2;

if(*cat<=2){
cout<<"\n Ingrese asignatura 3: "; cin>>p1->secciones.seccion2.asignatura3;
cout<<"\n Ingrese asignatura 4: "; cin>>p1->secciones.seccion2.asignatura4;
}
if(*cat<=5){
cout<<"\n Ingrese asignatura 5: "; cin>>p1->secciones.seccion1.asignatura5;
}
}

#36
Porque en ese bucle no hay nada que hacer en su cuerpo, sin embargo el lenguaje C requiere que todo bucle tenga un cuerpo. Para cumplir con esa regla se pone una sentencia nula:
/* sentencia nula (nada) */ ;

La convencion en estos casos es colocar la sentencia nula en una linea aparte:
while (cadena[++i] != '\0')
   ;


Un saludo
[/quote]

Gracias rir3760 ,Quiere decir que cuando una funcion de control contiene instrucciones simples como las anteriores, no es de primera necesidad las llaves?

#37
leosansan tu codigo me funciono, gracias por tu aporte, pero tengo algunas dudas:

fgets(cadena,100,stdin); /* stdin funciona como archivo no? de ser asi: cadena no deberia primero ser escrita en stdin para luego ser leida en esa archivo*/

while (cadena[++i]!='\0');
    i=i-1;
    while (i>=0)
        printf ("%c",cadena [i--]);
    printf ("\nPresione ENTER para salir:");
    while (getchar()!='\n') ;

/*por que en los while colocas ; y no llaves { }*/
#38
Deseo que el usuario introduzca una cadena y luego sea impresa al inverso, el problema es que el compilador me indica el siguiente error : 28  invalid conversion from `int' to `char*' y ademas en algunas ocasiones me salta a otro codigo fuente de instrucciones desconocidas.

#include<stdlib.h>
#include<stdio.h>
#include<string.h>

char invertir(char cad[80]);
int i,tam,nuevo[80];
main(){
       
       char cad[80];
       printf("Ingrese tamaño de la cadena (maximo 80 caracteres) : ");
       scanf("%d",&tam);
       
       printf("\n Ingrese cadena: ");
       
       for(i=0;i<tam;i++){
        scanf("%d",&cad);
       }
       
       printf("\n Cadena inversa: ");
       printf("%s",invertir(cad));
       printf("\n\n");
       system("pause");
       }
       
       char invertir(char cad[]){
            do{
             for(i=tam-1;i<=0;i++){             
            strcpy(nuevo,cad);
            return (nuevo);
            }while((getchar(cad))!=NULL)
                                   
            }
              }
           
#39
Deseo transferir array[3][6] a cada una de las funciones descritas en el programa, pero en la primera funcion llamada llenar el compilador me indica `array' undeclared (first use this function), hay error o falta algo?, soy novata.

#include<stdio.h>
#include<iostream>
using namespace std;

void llenar(int array[3][6]);
void imprimir(int array[3][6]);
void suma(int array[3][6],int array2[3][3],int n,int h);
int i,j;
main(){
       
 
        llenar(array);
        imprimir(array);
        suma(array,array2);
        system("pause");
        }
 
       
       void llenar(int array[][6]){
       for(i=1;i<=3;i++){
        for(j=1;j<=6;j++){
         printf("\n valor posicion [%d][%d]=",i,j);
         scanf("%d",&array[j]);
         }
          }
           }
         
         void imprimir(int array[][6]){
         for(i=1;i<=3;i++){
        for(j=1;j<=6;j++){
         printf("\n posicion[%d][%d]=%d",i,j,array[j]);
         }
           }
             }
         
         void suma(int array[][], int array2[][],int n,int h){
       
         for(i=1;i<=3;i++){
          n=1,h=0;                 
        for(j=1;j<=3;j++){
         array2[j]=array[j+h]+array[j+n];
         n++;
         h++;
         }
           }
         imprimir(array2);
       }
#40
#include<iostream>
#include<string.h>

using namespace std;
int n,i,fact;
int factorial( int n );
main (){

cout<<"ingrese numero:"<<endl;
cin>>n;
if(n<1){
cout<<"ERROR, intente de nuevo"<<endl;
}
else
cout<<"\n factorial:"<<factorial(n)<<"\n"<<endl;
system("pause");
}

int factorial(int n){
int fact=1;
for(n;n>=1;n--)
{
fact=fact*n;
}
return(fact);
}