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 - Mario Olivera

#11
 Entonces en un while nunca se pone EOF porque terminaria el programa sin ejecutar lo que está después de la estructura while?

con respecto al switch mi duda es sobre los espacios, que no pide de nuevo la calificacion si se escribe " a"
#12
 Hola gente, queria hacerles una pregunta, en la universidad el profesor de programación nos dijo que el ciclo repeat, o do while, no sirve, ya que no tenemos manejo de el, dijo que este ciclo es mortal y que no lo usemos.

Que piensan sobre esto? porque piensan eso?

Saludos! Espero respuestas!
#13
Cita de: T. Collins en 20 Mayo 2015, 02:45 AM
Código (cpp) [Seleccionar]
cout <<"entra";
cout <<" ";


Y lo peor de todo es que no me tiraba error -.- muchas gracias!
#14
 Hola gente tengo este problema en un for, que no lo puedo hacer entrar.

Dejo El código

Código (cpp) [Seleccionar]

for (int c=10; c >= 1; c--) // FILAS
{
for (int espacios=c; espacios <= 20; espacios++)
{
cout <"entra";
cout <" ";
}

for (int puntos=1; puntos <= c; puntos++) // DIBUJA PUNTOS
{
cout <<"*";
}
cout <<endl;
}
#15
 Hola gente, me surgio una pregunta, hice un código que evalua los numeros factoriales del 1 al 20, la variable de tipo int resultado me muestra cada resultado de la multiplicación, se que una variable int si mal no recuerdo va desde -32768 a 32767, pero llega a valer: 2004189184.

Todo esto esta en un ciclo for... la viariable por si sola se transforma en una long int?
#16
 Hola gente, tengo unas dudas con un switch y quisiera saber como hacer para que al ingresar eof (ctrl + z en windows, ctrl + d en linux) no se me cierre el programa y se ejecuten las otras funciones miembro.


Mi duda del switch es la siguiente en la funcion miembro recibirCalificaciones
si se ingresa por ejemplo " a" (espacio,y letra a), toma calificacion como "a", y quisiera saber por que, porque creo yo que tendria que entrar en default y no, se que evita los saltos de lineas, espacios y espacios tabulares, pero quisiera saber que pasa en ese cuerpo cuando tenemos un espacio y letra a.


Desde ya muchas gracias y Saludos!

Bueno este es el código:

main.cpp
Código (cpp) [Seleccionar]
#include <iostream>
using std::cin;

#include "LibroCalificaciones.h"

int main()
{
LibroCalificaciones miLibroCalificaciones("CS101 Programacion en C++");

miLibroCalificaciones.mostrarMensaje();
miLibroCalificaciones.recibirCalificaciones();
miLibroCalificaciones.mostrarReporteCalificaciones();
cin.get();
return 0;
}


LibroCalificaciones.h
Código (cpp) [Seleccionar]
#include <string>
using std::string;

class LibroCalificaciones
{
public:
LibroCalificaciones(string);
void establecerNombreCurso(string);
string obtenerNombreCurso();
void mostrarMensaje();
void recibirCalificaciones();
void mostrarReporteCalificaciones();
private:
string nombreCurso;
int aCuenta;
int bCuenta;
int cCuenta;
int dCuenta;
int fCuenta;
};

LibroCalificaciones.cpp
Código (cpp) [Seleccionar]
#include <iostream>
using std::cout;
using std::cin;
using std::endl;

#include "LibroCalificaciones.h"

//CONSTRUCTOR
LibroCalificaciones::LibroCalificaciones(string nombre)
{
establecerNombreCurso(nombre);
aCuenta=0;
bCuenta=0;
cCuenta=0;
dCuenta=0;
fCuenta=0;
}

void LibroCalificaciones::establecerNombreCurso(string nombre)
{
if (nombre.length() <= 25)
{
nombreCurso= nombre;
}
else
{
nombreCurso= nombre.substr(0,25);

cout <<"el nombre " <<nombre <<" excede la longitud maxima (25).\n"
<<"Se limito nombreCurso a los primeros 25 caracteres.\n";
}
}

string LibroCalificaciones::obtenerNombreCurso()
{
return nombreCurso;
}

void LibroCalificaciones::mostrarMensaje()
{
cout <<"Bienvenido al libro de calificaciones para " <<obtenerNombreCurso() <<"!\n";
}

void LibroCalificaciones::recibirCalificaciones()
{
int calificacion;

cout <<"Escriba las calificaciones de letra." <<endl
<<"Escriba el caracter EOF (fin de archivo) para terminar la entrada." <<endl;

while ((calificacion= cin.get()) != EOF)
{
switch (calificacion)
{
case 'A':
case 'a':
aCuenta++;
break;

case 'B':
case 'b':
bCuenta++;
break;

case 'C':
case 'c':
cCuenta++;
break;

case 'D':
case 'd':
dCuenta++;
break;

case 'F':
case 'f':
fCuenta++;
break;

case '\t':
case '\n':
case ' ':
break;

default:
cout <<"Se introdujo una letra de calificacion incorrecta."
<<"Escriba una nueva calificacion." <<endl;
break;
}
}
}

void LibroCalificaciones::mostrarReporteCalificaciones()
{
cout <<"\n\nNumero de estudiantes que recibieron cada Calificacion de letra:"
<<"\nA: " <<aCuenta
<<"\nB: " <<bCuenta
<<"\nC: " <<cCuenta
<<"\nD: " <<dCuenta
<<"\nF: " <<fCuenta
<<endl;
}
#17
Cita de: Peregring-lk en 18 Mayo 2015, 17:36 PM
En la sección de inicialización del `for` solo puedes tener una declaración compuesta. Es decir, tantas variables como quieras, pero del mismo tipo, separadas por comas....

Muchas gracias, solucionado!, Saludos!
#18
 Les dejo un código que hice, pasa un binario a decimal  :D

Saludos!

Código (cpp) [Seleccionar]
#include <iostream>
using std::cin;
using std::endl;
using std::cout;

#include <cmath>
using std::pow;

int main()
{
long int binario;
long int decimal=0;
long int auxBinario;
int resto;
bool respuesta= true;


cout <<"Binario: ";
cin  >> binario;

auxBinario= binario;

for (int contador=0; pow(10.,contador) < binario; contador++)
{
resto= auxBinario % 10;
auxBinario/= 10;

switch (resto)
{
case 0:
decimal+= (resto * pow(2.0,contador));
break;

case 1:
decimal+= (resto * pow(2.0,contador));
break;

default:
respuesta= false;
break;
}

}

if (respuesta == true)
{
cout <<"\nEl binario " <<binario <<" es " <<decimal <<endl;
}
else
{
cout <<"\nEl numero ingresado no es un binario!\n";
}
cin.get();
cin.get();
return 0;
}
#19
 Hola gente, tengo un problema en un for, dejo el codigo y el error que me tira :)

Código (cpp) [Seleccionar]
#include <iostream>
using std::cin;
using std::cout;

int main()
{
// Variables
int palindromo;
bool respuesta= true;


cout <<"palindromo: ";
cin >> palindromo;


for(int divisorMayor=10000,int divisorMenor=10; divisorMenor <= 10000,divisorMayor >= 10; divisorMenor*=10, divisorMayor/=10)
{
if ((palindromo / divisorMayor) != (palindromo / divisorMenor))
{
respuesta= false;
break;
}

palindromo%= divisorMayor;
palindromo/= divisorMenor;
}

if (respuesta == true)
{
cout <<"\nEl numero es un palindromo.";
}

else
{
cout <<"\nEl numero no es un palindromo.";
}

cin.get();
return 0;
}


ERROR:

Citar1>------ Operación Generar iniciada: proyecto: Deitel-Ejer4.26, configuración: Debug Win32 ------
1>  main.cpp
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(31): error C2062: tipo 'int' inesperado
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(31): error C2065: 'divisorMenor' : identificador no declarado
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(31): error C2065: 'divisorMenor' : identificador no declarado
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(31): error C2143: error de sintaxis : falta ';' delante de ')'
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(31): error C2143: error de sintaxis : falta ';' delante de ')'
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(32): error C2143: error de sintaxis : falta ';' delante de '{'
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(33): error C2065: 'divisorMenor' : identificador no declarado
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(36): error C2043: instrucción break no válida
1>c:\users\mario\desktop\programacion c++\deitel-ejer4.26\deitel-ejer4.26\main.cpp(40): error C2065: 'divisorMenor' : identificador no declarado
========== Generar: 0 correctos, 1 incorrectos, 0 actualizados, 0 omitidos ==========
#20
Programación C/C++ / [Aporte] fixedInteger.h
16 Mayo 2015, 23:15 PM
 Hola gente, estuve codeando un .h, el cual previene que cuando esperamos un valor de tipo integer y nos ingresan un valor de tipo string no nos tire error, y nos cierre el programa, les dejo un video, y el .h abajo, con un main.cpp para ejemplo de su uso de datos.

[youtube=640,360]https://www.youtube.com/watch?v=tnJqZjGz23A[/youtube]


Main.cpp

Código (cpp) [Seleccionar]
#include <iostream>
using std::cout;
using std::endl;
using std::cin;

#include <string>
using std::string;
using std::getline;

#include "fixedInteger.h"

int main()
{
string numero;

cout <<"numero: ";
getline(cin,numero);
cout <<endl;

fixedInteger aplicacion(numero);

cin.get();
return 0;
}


fixedInteger.h


Código (cpp) [Seleccionar]
/*
<<<<<<<<<<<FIXED INTEGER>>>>>>>>>>>>>>>>
                                                                                                                                   Creado por: Mario Olivera
MISION:
•Solucionar el error de cuando esperamos un integer y nos dan un string :)

USO:
•Use un objeto desde un .cpp ejemplo: "fixedInteger objeto(una variable string);"
• Para obtener el numero integer, solo ponga "objeto.obtenerInteger();" ejemplo: int numero= objeto.obtenerInteger();

Atencion: si usted esta esperando un numero integer positivo podria poner un if en su .cpp, ejemplo: si el numero es negativo
entonces ejecuto de nuevo las funciones de fixedInteger;

Nada Mas que decir, saludos! Mario Olivera.
*/



/////////////////////////////////////////////CODIGO ////////////////////////////////////////

#include <iostream>
using std::cout;
using std::endl;
using std::cin;

#include <string>
using std::string;

class fixedInteger
{
public:
fixedInteger(string numero)
{
convertidor(numero);
}

int obtenerInteger()
{
return numeroInteger;
}




void convertidor(string numero)
{
int ladoDelCuadrado=0;
int cantidadDeCaracteres;
int resultado=1;
int i=1;
string auxNumero= numero;
string caracter;
string primerCaracter;
string aux;
bool interruptor= false;
bool negativo= false;


cantidadDeCaracteres= (auxNumero.length());

auxNumero= "f" + auxNumero;

while (interruptor == false)
{
interruptor= true;
if (cantidadDeCaracteres == 1)
{
caracter= auxNumero[1];

if (caracter == "0")
{
ladoDelCuadrado= 0;
}
else
{
if (caracter == "1")
{
ladoDelCuadrado= 1;
}
else
{
if (caracter == "2")
{
ladoDelCuadrado= 2;
}
else
{
if (caracter == "3")
{
ladoDelCuadrado= 3;
}
else
{
if (caracter == "4")
{
ladoDelCuadrado= 4;
}
else
{
if (caracter == "5")
{
ladoDelCuadrado= 5;
}
else
{
if (caracter == "6")
{
ladoDelCuadrado= 6;
}
else
{
if (caracter == "7")
{
ladoDelCuadrado= 7;
}
else
{
if (caracter == "8")
{
ladoDelCuadrado=8;
}
else
{
if (caracter == "9")
{
caracter= 9;
}
else
{
interruptor= false;
}
}
}
}
}
}
}
}
}
}

}



else
{
primerCaracter= auxNumero[1];
aux= auxNumero[1];
while (i < cantidadDeCaracteres)
{

if ((aux == "+") || (aux == "-"))
{

}
else
{
resultado*= 10;
}
++i;
}
i= 1;

caracter= auxNumero[i];

if (caracter == "+")
{
i++;
}
if (caracter == "-")
{
i++;
negativo= true;
}

while (i < cantidadDeCaracteres)
{
caracter= auxNumero[i];
if (caracter == "0")
{

if ((primerCaracter != "+") || (primerCaracter != "-"))
{
if (i > 1)
{
ladoDelCuadrado= ladoDelCuadrado + ( 0 * resultado);
}

}
else
{
if (i > 2)
{
ladoDelCuadrado= ladoDelCuadrado + ( 0 * resultado);
}
}
resultado/= 10;
}
else
{
if (caracter == "1")
{
ladoDelCuadrado= ladoDelCuadrado + ( 1 * resultado);
resultado/= 10;
}
else
{
if (caracter =="2")
{
ladoDelCuadrado= ladoDelCuadrado + ( 2 * resultado);
resultado/= 10;
}
else
{
if (caracter == "3")
{
ladoDelCuadrado= ladoDelCuadrado + ( 3 * resultado);
resultado/= 10;
}
else
{
if (caracter == "4")
{
ladoDelCuadrado= ladoDelCuadrado + ( 4 * resultado);
resultado/= 10;
}
else
{
if (caracter == "5")
{
ladoDelCuadrado= ladoDelCuadrado + ( 5 * resultado);
resultado/= 10;
}
else
{
if (caracter == "6")
{
ladoDelCuadrado= ladoDelCuadrado + ( 6 * resultado);
resultado/= 10;
}
else
{
if (caracter == "7")
{
ladoDelCuadrado= ladoDelCuadrado + ( 7 * resultado);
resultado/= 10;

}
else
{
if (caracter == "8")
{
ladoDelCuadrado= ladoDelCuadrado + ( 8 * resultado);
resultado/= 10;
}
else
{
if (caracter == "9")
{
ladoDelCuadrado= ladoDelCuadrado + ( 9 * resultado);
resultado/= 10;
}
else
{
interruptor= false;
}
}
}
}
}
}
}

}
}


}
++i;


}

}

if (cantidadDeCaracteres != 1)
{
caracter= auxNumero.substr(2,cantidadDeCaracteres);

if ((caracter != "0") && (caracter != "1") && (caracter != "2")  && (caracter != "3")  && (caracter != "4")  && (caracter != "5")  && (caracter != "6")  && (caracter != "7")  && (caracter != "8")  && (caracter != "9"))
{
interruptor= false;
}

if (interruptor == true)
{
caracter= auxNumero.substr(cantidadDeCaracteres);

if (caracter == "1")
{
ladoDelCuadrado= ladoDelCuadrado + 1;
}
else
{
if (caracter == "2")
{
ladoDelCuadrado= ladoDelCuadrado + 2;
}
else
{
if (caracter == "3")
{
ladoDelCuadrado= ladoDelCuadrado + 3;
}
else
{
if (caracter == "4")
{
ladoDelCuadrado= ladoDelCuadrado + 4;
}
else
{
if (caracter == "5")
{
ladoDelCuadrado= ladoDelCuadrado + 5;
}
else
{
if (caracter == "6")
{
ladoDelCuadrado= ladoDelCuadrado + 6;
}
else
{
if (caracter == "7")
{
ladoDelCuadrado= ladoDelCuadrado + 7;
}
else
{
if (caracter == "8")
{
ladoDelCuadrado= ladoDelCuadrado + 8;
}
else
{
ladoDelCuadrado= ladoDelCuadrado + 9;
}
}
}
}
}
}
}
}

}
else
{

cout <<"ingrese el valor nuevamente: ";
getline(cin, auxNumero);

ladoDelCuadrado=0;
resultado=1;
i=1;
interruptor= false;
cantidadDeCaracteres= (auxNumero.length());
auxNumero= "f" + auxNumero;
}

}
else
{
if (interruptor == false)
{
cout <<"ingrese el valor nuevamente: ";
getline(cin, auxNumero);

ladoDelCuadrado=0;
resultado=1;
i=1;
interruptor= false;
cantidadDeCaracteres= (auxNumero.length());
auxNumero= "f" + auxNumero;
}
}
}

if (negativo == true)
{
ladoDelCuadrado= ladoDelCuadrado * -1;
}

numeroInteger= ladoDelCuadrado;
}

private:
string mensajeError;
int numeroInteger;

};