O problema apresenta uma entrada simples: a hora atual e a do despertador, dividida em quatro inteiros. Os dois primeiros para a hora atual (horas e minutos, respectivamente), repetindo a estrutura para a hora do despertador. Como nos interessa o número de minutos dormidos, a solução passa por um passo obrigatório: converter o valor de horas e minutos para o número de minutos corridos do dia (de um total de 1440, isto é, 24*60). Tal conta é feita da seguinte forma:
mdia=hora*60+minutos
Se calcularmos a diferença desse valor em minutos da hora do despertador com a hora atual, temos os minutos que a Daniela vai conseguir dormir. Porém, temos um caso omisso: e se o despertador for tocar no dia seguinte? Por exemplo, se a Daniela dormir às 22:00 e acordar às 6:00, temos que a hora inicial em minutos é 1320, sendo a hora do despertador é 360. Se fizermos a diferença do final para o início, temos um valor negativo (360-1320=-960).
Aí entra o jogo de cintura do aluno, porquê ao fazer essa diferença, o valor negativo indica o número de minutos entre o horário do despertador e o horário do início do sono, ou seja, o complemento do valor que nós queremos em um dia (faz um círculo que é mais fácil de entender). Oras, se temos o complemento, basta somar a este valor o número de minutos total de um dia (1440) que temos o valor correto:
1440+(360-1320)=1440-960=480
Assim, a lógica tem que considerar o seguinte: se o resultado da conta em minutos for positivo, esse é o valor correto e é só imprimir. Se for negativo, basta somar 1440. E voilà, temos aqui o programa em C que resolve em tempo linear O(n) o prolema do alarme despertador. Q.E.D..
2 comentários:
Fiquei surpreso como saiu rápido em C. A parte mais chata para mim é a leitura dos dados, pensei em Perl na hora para resolver, mas em C ficou quase tão simples quanto :P
C é uma linguagem que resolve muitas coisas de maneira simples. Aliás, C foi feito pensando em programas se comunicando pelo stdin e stdout. O problema é ela não ser ensinada como tal hoje em dia. Claro, em Java a parte de entrada de dados ia ser o cão :). Tenho pena dos alunos que inventam de fazer em Java. Uma equipe da UTFPR lamentou ter feito essa escolha.
Postar um comentário