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 - DEaniz

#1
Hola, estoy creando un programa que me de el promedio de agua gastada
semanalmente
ya cree el archivo .cvs y así
pero lo que no se es como ingresar los datos
ya intente de mil y un formas pero no se ponen los datos
si alguien supiera decirme que estoy haciendo mal,
o si hay algun comando para poder hacerlo,
gracias
Código (cpp) [Seleccionar]
#include<iostream>
#include<fstream>
using namespace std;
#include<stdlib.h>
#include<conio.h>
int main()
{
    int l ,m ,mi, j, v,s,d;
char cad[100];
ofstream sal("libro.csv");
sal<<" _,lunes, martes, miercoles,jueves, viernes, sabado, domingo"<<endl;
sal<<"Litros de agua diarios, 3 , 3 , 3 , 3 , 3 , 3 , 3 "<<endl;
sal<<"horas de baño: ";
cin>>l>>m>>mi>>j>>v>>s>>d;
sal<<, l, m, mi, j, v, s, d<<endl<<endl;

sal<<"Promedio:"<<endl;
sal<<",,,,,,,promedio semanal";

sal.close();
ifstream ent("libros.txt");
while(ent.getline(cad,100))
{cout<<cad<<endl;
}

ent.close();
cin.get();
return 0;
}
#2
Programación C/C++ / Re: Pilas y colas
19 Junio 2015, 02:17 AM
Cita de: 0xFer en 19 Junio 2015, 02:01 AM
char Pila::Pop(void){}

Fijate que no tiene parámetros y tú le estas pasando un char, que me imagino que es el carácter que quieres eliminar


Si. pero como podría corregir ese error, esque no te entiendo bien, gracias!
#3
Programación C/C++ / Re: Pilas y colas
19 Junio 2015, 02:15 AM

1Practica-5-estructuras-parentesis.cpp||In function 'int main()':|
1Practica-5-estructuras-parentesis.cpp|166|error: no matching function for call to 'Pila::Pop()'|
1Practica-5-estructuras-parentesis.cpp|166|note: candidate is:|
1Practica-5-estructuras-parentesis.cpp|62|note: int Pila::Pop(char)|
1Practica-5-estructuras-parentesis.cpp|62|note:   candidate expects 1 argument, 0 provided|
||=== Build failed: 1 error(s), 0 warning(s) (0 minute(s), 1 second(s)) ===|


Estos son los errores que marca
#4
Programación C/C++ / Re: Pilas y colas
19 Junio 2015, 01:32 AM
me marca error en el pop, y me hace cíclica la función.
#5
Programación C/C++ / Pilas y colas
19 Junio 2015, 01:06 AM
Hola, hice este programa donde se tiene que usar colas y pilas para poder balancear una ecuacion, es decir, si pongo mas parentesis de lo debido me debe aparecer que le faltan parentesis
si no pues solo poner que esta correcto.
pero me marca error, y la verdad no se porque
si alguien me pudiera ayudar y/o asesorar porfavor, gracias

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

class nodo{
    private:
        nodo *siguiente;
        char parentesis;
    public:
        nodo(char p, nodo *s=NULL){parentesis=p; siguiente=s;}
        nodo* regresaSiguiente(void); //{return siguiente;}
        char regresaParentesis(void);
        void modificaParentesis(char);
        void modificaSiguiente(nodo*);

};


nodo* nodo::regresaSiguiente(void)
{
    return siguiente;
}

char nodo::regresaParentesis(void)
{
    return parentesis;
}

void nodo::modificaParentesis(char p)
{
    parentesis=p;
}

void nodo::modificaSiguiente(nodo* s){
    siguiente=s;
}
////////////////////////////////////FIN DE LA CLASE NODO///////////////////////////////////////

class Pila
{
private:
    nodo*tope;
public:
    Pila(){tope=NULL;}
    void Push(char);
    char Pop(void);
    char Tope(void)
    {return tope-> regresaParentesis();}
    char PilaVacia()
    {return tope == NULL;}

};

void Pila::Push(char p)
{
    tope=new nodo(p, tope);
}

char Pila::Pop(void)
{
    char p;
    nodo*aux;
    delete(aux);
    return p;
    if(!PilaVacia());
}


class Cola
{
private:
    nodo*cabeza;
    nodo*extremo;

public:
    Cola(){cabeza=extremo=NULL;}
    void Suma(char);
    char Elimina(void);
    int colaVacia(void){return cabeza==NULL;}
    //~ Cola();

};

void Cola::Suma(char p)
{
    if(!extremo)
    {

        extremo=cabeza=new nodo(p,NULL);
        //extremo=cabeza;
    }
    else{
        nodo*aux;
        aux=new nodo(p);
        extremo-> modificaSiguiente(aux);
        extremo=extremo -> regresaSiguiente();

    }

}

char Cola::Elimina(void)
{
    char p=-1;
    if(!colaVacia())
    {
    nodo*aux=cabeza;
    cabeza=cabeza->regresaSiguiente();
    p=aux->regresaParentesis();
    delete(aux);
    }

    return p;
}



int main()
{
    char caracter[10];
    int i;
    char c;
    Cola obj;
    Pila p;

    cout<<"escribe la funcion: "<< endl;
    cin.getline(caracter,10);

  while( caracter[i] != '\0')
    {
        obj.Suma(caracter[i]);
    }

    while(!obj.colaVacia())
    {
        c=obj.Elimina();
        if(c=='(')
           {
            p.Push(c);
           }
        else if(c==')')
            {
            p.Pop(c);
            }
    }
    if(!p.PilaVacia())
    {

        cout<<"Falta un parentesis "<<endl;
    }
if(p.PilaVacia())
{
cout<<"Todo esta bien"<<endl;
}

    return 0;


}
#6
Hola, buenas tardes, quisiera saber si alguien me podría ayudar,
hice un programa de listas enlazadas, pero use struct, ya que se me hacia mas facil crear un programa así, pero mi maestra me dijo que no tenia que ser con struct, sino con CLASES, y no se como hacer mi mismo programa pero con clases,
alguien que me pueda orientar o ayudar porfavor?
MUCHAS GRACIAS

_________________________________________________
Este es mi programa


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

typedef struct dato nodo;

nodo* crear_lista(nodo* lista);
nodo* ingresar_dato(char* nombre, int boleta, nodo* lista);

void mostrar_lista(nodo* lista);
void mostrar_nodo(nodo* elemento);
void menu(void);

void borrar_lista(nodo* lista);
nodo* borrar_nodoxnombre(char *nombre, nodo* lista);
nodo* borrar_nodoxnota(int boleta, nodo* lista);

nodo* buscar_nodo(nodo* lista, char *caracter);
void ordenar_lista(nodo* lista);



struct dato
    {
    char nombre[80];
    int nota;
    struct dato *sig;
    };

nodo* crear_lista(nodo* lista)
    {
    return (lista = NULL);
    }

nodo* ingresar_dato(char* nombre, int boleta, nodo* lista)
    {
    nodo *nuevo_dato;
    nodo *auxiliar = NULL;

    nuevo_dato = (nodo*)malloc(sizeof(nodo));

    if(nuevo_dato != NULL)
        {
        strcpy((nuevo_dato->nombre), nombre);
        nuevo_dato->nota = boleta;
        nuevo_dato->sig = NULL;

        if(lista == NULL)
            lista = nuevo_dato;
        else
            {
            auxiliar = lista;
            while(auxiliar->sig != NULL)
                auxiliar = auxiliar->sig;
            auxiliar->sig = nuevo_dato;
            }
        }
    else
         cout<<"\n\nNo se pudo reservar memoria\n\n";
    return lista;
    }

void mostrar_lista(nodo* lista)
    {
    nodo *auxiliar;
    int contador = 0;

    if(lista == NULL)
        cout<<"\n\nLa lista esta vacia\n\n";

    auxiliar = lista;
    while(auxiliar != NULL)
        {
         cout<<"\n\nPersona"<<(contador+1);
         cout<<"\nNombre y Apellido: "<<auxiliar->nombre;
         cout<<"\n\nBoleta:      "<< auxiliar->nota;
        contador++;

        auxiliar = auxiliar->sig;
        }
   cout<<"\nFin de lista\n\n";
    }

void borrar_lista(nodo* lista)
    {
    nodo *borra;

    borra = lista;
    while(borra)
        {
        lista = lista->sig;
        free(borra);
        borra = lista;
        }
    }

void menu(void)
    {

     cout<<"\n\nLista_Practica_3             3CM7:\n\n";
     cout<<"1) Ingresar dato\n";
    cout<<"2) Mostrar lista\n";
   cout<<"3) Borrar lista\n";
    cout<<"4) Borrar por nombre\n";
     cout<<"5) Borrar por boleta\n";
     cout<<"6) Buscar en lista\n";
     cout<<"7) Ordenar lista\n";
    cout<<"0)SALIR\n\n";


    }

nodo* borrar_nodoxnombre(char *nombre, nodo* lista)
     {
    if(lista != NULL)
        {
        nodo *ptraux;
        nodo *ptranterior = NULL;
        int cont;

        ptraux = lista;
        while(ptraux != NULL && (strcmp(ptraux->nombre, nombre) != 0))
            {
            ptranterior = ptraux;
            ptraux = ptraux->sig;
            cont++;
            }
        if(cont == 1 && ptraux->sig == NULL)
            {
            free(ptraux);
            lista = NULL;
            }
        if(ptraux == NULL)
            cout<<"\n\nNo se encontro una persona con ese nombre\n\n";
        else if(ptranterior == NULL)
            {
            lista = lista->sig;
            free(ptraux);
            }
        else
            {
            ptranterior->sig = ptraux->sig;
            free(ptraux);
            }
        }

    return lista;
    }

nodo* borrar_nodoxnota(int boleta, nodo* lista)
        {
    if(lista != NULL)
        {
        nodo *ptraux;
        nodo *ptranterior = NULL;
        int cont = 0;

        ptraux = lista;
        while(ptraux != NULL && ptraux->nota != boleta)
            {
            ptranterior = ptraux;
            ptraux = ptraux->sig;
            cont++;
            }
        if(cont == 1 && ptraux->sig == NULL)
            {
            free(ptraux);
            lista = NULL;
            }
        if(ptraux == NULL)
            cout<<"\n\nNo se encontro una persona con ese numero de boleta\n\n";
        else if(ptranterior == NULL)
            {
            lista = lista->sig;
            free(ptraux);
            }
        else
            {
            ptranterior->sig = ptraux->sig;
            free(ptraux);
            }
        }

    return lista;
    }

nodo* buscar_nodo(nodo* lista, char *caracter)
    {
    nodo *aux;
    char noabuscar[20];
    char a[] = "a";
    char b[] = "b";
    int nabuscar;
    if(lista != NULL)
        {
        if(strcmp(caracter,a) == 0)
            {
            cout<<"\n\nIngrese el nombre a buscar: ";
            fflush(stdin);
            fgets(noabuscar, 20, stdin);
            aux = lista;
            while(aux != NULL)
                {
                if(strcmp(aux->nombre, noabuscar) == 0)
                    return aux;
                aux = aux->sig;
                }
            return aux;
            }
        else if(strcmp(caracter,b) == 0)
            {
            cout<<"\n\nIngrese la nota a buscar: ";
            fflush(stdin);
            cout<<nabuscar;
            aux = lista;
            while(aux != NULL)
                {
                if(aux->nota == nabuscar)
                    return aux;
                aux = aux->sig;
                }
            return aux;
            }
         else
            {
            cout<<"\n\nOpcion no valida\n\n";
            return 0;
            }
        }
    }

void mostrar_nodo(nodo* elemento)
    {
    nodo* nodoencontrado;
    nodoencontrado = elemento;
    if(nodoencontrado == NULL)
       cout<<"\n\nNo se obtuvieron resultados\n\n";


    else
        {
        cout<<"\n\nNodo encontrado:\n\n";
        cout<<"\nNompre y apellido:"<< nodoencontrado->nombre;
        cout<<"\nBoleta:  "<< nodoencontrado->nota;

        }
    }
/*    \n\n\n\n   */

void ordenar_lista(nodo* lista)
    {
    nodo *anterior;
    nodo *siguiente;
    nodo temp;

    anterior = lista;

    while(anterior->sig != NULL)
        {
        siguiente = anterior->sig;

        while(siguiente != NULL)
            {
            if(strcmp(anterior->nombre, siguiente->nombre) > 0)
                {
                strcpy(temp.nombre, siguiente->nombre);
                temp.nota = siguiente->nota;
                strcpy(siguiente->nombre, anterior->nombre);
                siguiente->nota = anterior->nota;
                strcpy(anterior->nombre, temp.nombre);
                anterior->nota = temp.nota;
                }
            siguiente = siguiente->sig;
            }
        anterior = anterior->sig;
        siguiente = anterior->sig;
        }
cout<<"\n\nLista ordenada\n\n";


    }

    int main(int argc, char** argv)
    {
    nodo *inicio;
    nodo *nodobuscado;
    char nom[20];
    char nomaborrar[20];
    int nborrar;
    int nota, i, cant, op;
    char s[2];

    inicio = crear_lista(inicio);

    menu();
    cin>>op;
    while(op != 0)
        {
        switch(op)
            {
            case 1: cout<<"\n\nQue cantidad de datos ingresara: ";
                    cin>>cant;
                    cout<<"\n\n";

                    cout<<"Ingreso de datos:\n\n";
                    for(i=0 ; i < cant ; i++)
                        {
                        cout<<"Nombre y apellido: ";
                        fflush(stdin);
                        fgets(nom, 80, stdin);
                       cout<<"\nBoleta:      ";
                        fflush(stdin);
                        cin>>nota;
                        cout<<"\n\n";
                        inicio = ingresar_dato(nom, nota, inicio);
                        }
                    break;

            case 2: mostrar_lista(inicio);
                    break;

            case 3: borrar_lista(inicio);
                    free(inicio);
                    cout<<"\n\nLista Borrada\n\n";
                    inicio = NULL;
                    break;

            case 4: cout<<"\n\nIngrese el nombre a borrar\n\n";
                    fflush(stdin);
                    fgets(nomaborrar, 80, stdin);
                    inicio = borrar_nodoxnombre(nomaborrar, inicio);
                    break;

            case 5: cout<<"\n\nIngrese la nota a borrar\n\n";
                    fflush(stdin);
                    cin>>nborrar;
                    inicio = borrar_nodoxnota(nborrar, inicio);
                    break;

            case 6: cout<<"\n\n('a') para buscar por nombre || ('b') para buscar por nota\n\n";
                    fflush(stdin);
                    fgets(s, 2, stdin);
                    nodobuscado = buscar_nodo(inicio, s);
                    mostrar_nodo(nodobuscado);
                    break;

            case 7: ordenar_lista(inicio);
                    break;



            default: cout<<"\n\n Este no es una opcion, intentelo nuevamente// \n\n";
            }
             getch();
            system("cls");
        menu();
        cin>>op;
        }


    return (EXIT_SUCCESS);
    }