¿Por favor alguien puede ayudarme con este ejercicio en C#?

Iniciado por palentino12, 14 Octubre 2015, 18:07 PM

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

palentino12

El ejercicio es el siguiente

Crea un programa que lleve el stock de bolígrafos y lapices de una papelería y que por tanto haga los siguientes pasos:

- El programa pedirá inicialmente cuantos bolígrafos y cuantos lapices hay en stock. Éste paso sólo se realizará una vez.

- Entonces el programa debe pedir al usuario una letra mientras exista stock de bolígrafos o lapices.

- Después de pedir la letra, si está es B o L, el programa pedirá al usuario que introduzca una cantidad,

- Se deberá restar la cantidad introducida del stock total de bolígrafos o lapices dependiendo de la letra introducida.

- El programa volverá a pedir la letra y stock hasta que se termine el stock de algunos de los productos. Entonces debe finalizar el programa mostrando la cantidad de bolígrafos y lapices que quedan en la tienda.


Osea cuando le de a ejecutar el programa, me tendría que salir por ejemplo esto.

Stock de bolígrafos?
30

Stock de lapices?
20

Introduce producto?
B

Introduce Cantidad?
15

Introduce producto?
L

Introduce Cantidad?
5

Introduce producto?
B

Introduce Cantidad?
15

Fin del programa
Quedan 0 boligrafos y 15 lapices.

Este es el código que hice, pero no es que me de error, es que simplemente no me da el resultado esperado, osea no me repite el proceso hasta que la que condición se cumpla.

Código (csharp) [Seleccionar]

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace stocks__boligrafos_lapices
{
   class Program
   {
       static void Main(string[] args)
       {
           int boligrafos, lapices, cantidad1, cantidad2, resultado1 = 0, resultado2 = 0;

           char respuesta;


           Console.WriteLine("Stock de bolígrafos?");
           Console.WriteLine("");

           boligrafos = Int16.Parse(Console.ReadLine());
           Console.WriteLine("");

           Console.WriteLine("Stock de lapices?");
           Console.WriteLine("");

           lapices = Int16.Parse(Console.ReadLine());
           Console.WriteLine("");



           do
           {
               Console.WriteLine("Introduce producto");
               Console.WriteLine("");

               respuesta = char.Parse(Console.ReadLine());
               Console.WriteLine("");

               if ((respuesta == 'B') || (respuesta == 'L'))
               {
                   Console.WriteLine("Introduce cantidad");
                   Console.WriteLine("");
                   cantidad1 = Int16.Parse(Console.ReadLine());
                   resultado1 = boligrafos - cantidad1;
                   Console.WriteLine("");
                   Console.WriteLine("Introduce producto");
                   Console.WriteLine("");
                   respuesta = char.Parse(Console.ReadLine());
                   Console.WriteLine("");
                   Console.WriteLine("Introduce cantidad");
                   Console.WriteLine("");
                   cantidad2 = Int16.Parse(Console.ReadLine());
                   resultado2 = lapices - cantidad2;
                   Console.WriteLine("");
               }
               else
               {
                   Console.WriteLine("Error");
               }



           }
           while ((resultado1 <= 0) || (resultado2 <= 0));

           Console.WriteLine("");
           Console.WriteLine("Fin del programa");
           Console.WriteLine("Quedan " + resultado1 + " boligrafos" + " y " + resultado2 + " lapices.");

           Console.ReadKey();



       }
   }
}



Alguien puede ayudarme?

Gracias y un saludo.

Mod: Tema movido

Eleкtro

#1

  • 1. La condición del loop es incorrecta:
    while ((resultado1 <= 0) || (resultado2 <= 0));

    Se puede traducir cómo "Mientras que resultado1 sea igual o menor que 0, o resultado2 sea igual o menos que 0.". Nótese el "Mientras que". Necesitas hacer lo opuesto, "Hasta que".

  • 2. La lógica del búcle es incorrecta, indiferentemente de si la cantidad del stock se agota, tú seguirás preguntando y descontando.

Así lo puedes corregir:
Código (csharp) [Seleccionar]
static void Main(string[] args) {

   int penStock = 0;
   int pencilStock = 0;
   int penCount = 0;
   int pencilCount = 0;
   char userValue = '\0';

   Console.Write("¿Stock de bolígrafos: ");
   penStock = int.Parse(Console.ReadLine());

   Console.Write("¿Stock de lápìces: ");
   pencilStock = int.Parse(Console.ReadLine());

   while (!((penStock <= 0) || (pencilStock <= 0))) {

       Console.WriteLine();
       Console.Write("Introduce el producto a elegir (B o L): ");
       userValue = char.ToUpper(Console.ReadKey().KeyChar);

       if (new char[]{'B', 'L'}.Contains(userValue)) {

       Console.WriteLine();

       switch (userValue) {

       case 'B':
       Console.Write("Introduce cantidad a descontar de bolígrafos: ");
       penCount = int.Parse(Console.ReadLine());
       penStock = (penStock - penCount);
       break;

       case 'L':
       Console.Write("Introduce cantidad a descontar de lápìces: ");
       pencilCount = int.Parse(Console.ReadLine());
       pencilStock = (pencilStock - pencilCount);
       break;

               default:
                   // Do nothing...
                   break;

       }

       } else {
       Console.WriteLine("Error");

       }

   }

   Console.WriteLine();
   Console.WriteLine("Fin del programa");
   Console.WriteLine(string.Format("Quedan {0} bolígrafos y {1} lápices.", penStock, pencilStock));

   Console.ReadKey();
   Environment.Exit(0);

}


Sin embargo, yo lo haría más o menos así, de una manera simplificada y rehutilizable:

Código (csharp) [Seleccionar]
using System;
using System.Linq;
using System.Text;
using System.Collections.Generic;

+
Código (csharp) [Seleccionar]
public sealed class StockItem
{

public char Letter {
get { return this.letterB; }
}
private char letterB;

public string Description {
get { return this.descriptionB; }
}
private string descriptionB;

public int Amount { get; set; }

public StockItem(char letter, string description, ref int amount) {
this.letterB = letter;
this.descriptionB = description;
this.Amount = amount;
}

}

+
Código (csharp) [Seleccionar]
static void Main(string[] args) {
   
   int penCount = 0;
   int pencilCount = 0;

   List<StockItem> items = new List<StockItem> {
       new StockItem('B', "bolígrafos", ref penCount),
       new StockItem('L', "lápices", ref pencilCount)
   };
   StockItem selectedItem = default(StockItem);

   foreach (StockItem item in items) {
       Console.Write(string.Format("¿Stock de {0}: ", item.Description));
       item.Amount = int.Parse(Console.ReadLine());
   }

   while ((from item in items select item.Amount).Min() > 0)  {
     
       Console.WriteLine();
       Console.Write("Introduce el producto a elegir: ");
       char userInput = char.ToUpper(Console.ReadKey().KeyChar);

       selectedItem = items.FirstOrDefault(item => char.ToUpper(item.Letter).Equals(userInput));

       if ((selectedItem != null)) {
       Console.WriteLine();
       Console.Write(string.Format("Introduce cantidad a descontar de {0}: ", selectedItem.Description));
       selectedItem.Amount = (selectedItem.Amount - int.Parse(Console.ReadLine()));

       } else {
       Console.WriteLine("Error");

       }

   }

   Console.WriteLine();
   Console.WriteLine("Fin del programa.");

   StringBuilder sb = new StringBuilder();
   foreach (StockItem item in items) {
       sb.AppendLine(string.Format("Quedan {0} {1}.", item.Amount, item.Description));
   }
   Console.WriteLine(sb.ToString());

   Console.ReadKey();
   Environment.Exit(0);

}


Saludos








palentino12

Muchas gracias por tu ayuda. Lo del segundo código que has puesto la verdad es que todavía no he llegado a ver lo del foreach, private, from, select, amount, description, format, Min .....................................

Si lo del do while era hasta que, osea se repetira hasta que resultado1 fuera igual o menos que 0 o resultado2 sea igual o menos que 0.


Un Saludo y gracias por tu ayuda.