Ayuda con un programa de C++ de resistencias de bandas 4, 5, 6 bandas

Iniciado por chaneque_14, 4 Diciembre 2020, 04:59 AM

0 Miembros y 1 Visitante están viendo este tema.

chaneque_14

Nose como añadir una opcion para 5 y 6 bandas, y como darle la opcion de mostrarle la demas tolerancias ademas del dorado y plateado. Necesito Ayuda. Gracias.
Código (cpp) [Seleccionar]
#include<iostream>
using namespace std;
int main(){

int n1, n2, n3;
cout<<"\nNegro     = 1 ";
cout<<"\nCafe      = 2 ";
cout<<"\nRojo      = 3 ";
cout<<"\nNaranja   = 4 ";
cout<<"\nAmarillo  = 5 ";
cout<<"\nVerde     = 6 ";
cout<<"\nAzul      = 7 ";
cout<<"\nPurpura   = 8 ";
cout<<"\nGris      = 9 ";
cout<<"\nBlanco    = 10 ";

cout<<"\n¿Cual es el primer color? :";cin>>n1;
cout<<"\n¿Cual es el segundo color? :";cin>>n2;
cout<<"\n¿Cual es el tercer color? :";cin>>n3;

cout<<n1<<n2;

for(int i=0; i<n3; i++){

cout<<0;
}

int n4;
cout<<"\nDigite el numero que aparecio :"; cin>>n4;

float n5, n6;

cout<<"\nDorado = 5%";
cout<<"\nPlateado = 10%";

cout<<"\nEscribe el porcentaje dependiendo el color: "; cin>>n5;

if((n5>=5)and(n5>=10)){

n6=((5)*(4))/100;
cout<<"\nSu porcentaje = "<<n6<<endl;
}
else{
n6=((10)*(n4))/100;
cout<<"\nSu porcentaje = "<<n6<<endl;
}

int suma= 0,resta=0;

suma= n4+ n6;
resta= n4 - n6;

cout<<"\nSu limite de rango mayor es de : "<<suma<<endl;
cout<<"\nSu limite de rango menor es de : "<<resta<<endl;

return 0;

}

K-YreX

Problemas que le veo a ese programa:
  • Los nombres de las variables no ayudan a entender el código.
  • Siempre hay que suponer que un usuario se puede equivocar por lo que cuantas menos veces dependamos de él mejor. Con esto quiero decir que las líneas 21-29 es mejor evitarlas. Es un cálculo que puedes hacer internamente sin necesidad del usuario.
  • La condición de la línea 38 se puede simplificar: (n >= 5) && (n >= 10) es lo mismo que: (n >= 10). Siempre que la segunda condición sea cierta, la primera también lo será y es imposible que la segunda sea cierta sin serlo la primera también. De todas formas este bloque de if-else no tiene mucho sentido tal y como está planteado.
  • En la línea 40 utilizas 4 en vez de n4.

    No sé mucho de resistencias (recuerdo un poco de cuando estudiaba física o tecnología) y mirando por Internet veo que hay diferentes tablas de medida sobre todo para el porcentaje final.
    Por lo tanto es importante que especifiques las necesidades que tiene que suplir tu código.

    De momento te puedo ayudar en lo siguiente, si quieres hacer el programa válido para un número diferente de bandas, haz lo siguiente:
    Código (cpp) [Seleccionar]

    // Definimos una constante para el maximo de bandas:
    const int MAX_BANDAS = 6;

    int main(){
      // Creamos un array para guardar el valor de cada banda:
      int bandas[MAX_BANDAS]; // Pueden sobrar espacios pero la solucion mas correcta requiere de memoria dinamica y es mas avanzado
      int numeroBandas;
      // Con este do-while evitas que el usuario pueda introducir numeros fuera del rango indicado en el while() -> [4, 6]
      do {
        cout << "Introduce el numero de bandas de la resistencia: ";
        cin >> numeroBandas;
      } while(numeroBandas < 4 || numeroBandas > 6);
      // la ultima banda es diferente pero las demas son iguales por lo que repetimos lo de preguntar color numeroBandas-1 veces:
      // AQUI muestras los colores como lo haces ahora...
      for(int i = 0; i < numeroBandas - 1; ++i){
        // Con este do-while evitas que introduzcan valores no validos
        // PD: He estado revisando algunas tablas y el negro corresponde al 0, no al 1
        do {
          cout << "Introduce el valor numerico de la banda " << (i+1) << ": ";
          cin >> bandas[i];
        } while(bandas[i] < 0 || bandas[i] > 9);
      }
      // Una vez que llegas aqui ya tienes todos los colores menos el ultimo
      // Este tendras que hacerlo por separado segun los colores que consideres validos
      // El ultimo lo guardas en bandas[numeroBandas-1] que es la ultima posicion valida del array

      // Ahora toca calcular el valor:
      int resistencia = 0;
      for(int i = 0; i < numeroBandas - 1; ++i){
        resistencia = bandas[i] * pow(10, i); // Para usar pow() tienes que incluir la biblioteca cmath al principio: #include <cmath>
        // La funcion pow() en este caso es innecesaria pero es para que veas la operacion
        // Tambien puedes usar un multiplicador que empiece en 1 y en cada vuelta se multiplique por 10 <- Mas eficiente, intentalo
      }

      // Ahora toca calcular el minimo y maximo del rango segun el porcentaje de la ultima banda:
      // Esto lo puedes hacer con un switch-case o guardando todos los valores posibles en otro array: porcentajes
      // Suponiendo la segunda opcion, utilizas el valor del array guardado en la posicion elegida por el usuario al mostrarle las opciones
      float variacion = resistencia * porcentajes[bandas[numeroBandas-1]];
      float resistenciaMinima = resistencia - variacion;
      float resistenciaMaxima = resistencia + variacion;
    }


    Aunque el código parece bastante grande, hay muchos comentarios y fragmentos que tienes que completar tú.
    Si tienes algún problema, coméntalo teniendo en cuenta los comentarios que he ido haciendo a lo largo del código.
Código (cpp) [Seleccionar]

cout << "Todos tenemos un defecto, un error en nuestro código" << endl;

chaneque_14

Muchas gracias por la ayuda, fue de mucha ayuda que me hicieras notar mis errores.