Meu Do/While funciona, porém, é o ideal?
Boa noite!!
Estou tentando aplicar uma repetição utilizando o WHILE utilizando também da condição IF, que retorna uma mensagem para o usuário caso o mesmo digite um valor inválido. Apesar de estar funcionando, eu gostaria de saber se essa é a maneira mais adequada e se existe uma forma mais prática de se resolver situações como essa. Obrigado desde já!!!
Estou tentando aplicar uma repetição utilizando o WHILE utilizando também da condição IF, que retorna uma mensagem para o usuário caso o mesmo digite um valor inválido. Apesar de estar funcionando, eu gostaria de saber se essa é a maneira mais adequada e se existe uma forma mais prática de se resolver situações como essa. Obrigado desde já!!!
string dia; string mes; do { Console.WriteLine("Em que dia você nasceu?"); dia = Console.ReadLine(); if (Convert.ToInt32(dia) > 31) { Console.WriteLine("Digite dia válido"); } } while (Convert.ToInt32(dia) > 31); { //repare que aqui eu não escrevo nada } do { Console.WriteLine("Em que mês você nasceu?"); mes = Console.ReadLine(); if (Convert.ToInt32(mes) > 12) { Console.WriteLine("Digite mês válido"); } } while (Convert.ToInt32(mes) > 12); { //repare que aqui eu não escrevo nada }
Gerson Bueno
Curtidas 0
Melhor post
Mauricio Espido
27/01/2020
Pelo que parece, o seu input também está aceitando letras e números negativos, isso pode ser um problema.
GOSTEI 1
Mais Respostas
Gerson Bueno
26/01/2020
Pelo que parece, o seu input também está aceitando letras e números negativos, isso pode ser um problema.
Obrigado por ajudar! Entendo que ainda falta tratar esse problema dentro de uma repetição, vou trabalhar nisso também. Mas em relação a construção da estrutura DO/WHILE, você sabe se está de acordo com as boas práticas? O fato de eu não ter colocado nada dentro do WHILE me deixa ressabiado, parece que tá errado de alguma forma, mesmo que esteja funcionando.
GOSTEI 0
Mauricio Espido
26/01/2020
Pode resumir assim também, não testei mas acho que funciona e também removi sua string, sendo que o Console.ReadLine() é uma string, caso não funcionar, use dia_mes = Console.ReadLine(). Não vejo a necessidade de criar strings se ela é usada nos dois whiles.
do { Console.WriteLine("Em que dia você nasceu?"); if (Convert.ToInt32(Console.ReadLine()) > 31) { Console.WriteLine("Digite dia válido"); } } while (Convert.ToInt32(Console.ReadLine()) > 31) do { Console.WriteLine("Em que mês você nasceu?"); if (Convert.ToInt32(Console.ReadLine()) > 12) { Console.WriteLine("Digite mês válido"); } }while (Convert.ToInt32(Console.ReadLine()) > 12)
GOSTEI 1