Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Задачи _ Задача на время

Автор: Perfez 17.02.2007 22:59

Важно:Сразу прошу вас не пишите готовую программу ,а только объясните сам алгоритм в кратце: unsure.gif
yes2.gif Это задача с онлайн олимпиады:http://www.hsin.hr/coci/ yes2.gif
Даётся нынешнее время и время планировки,нужно сколько осталось(таймер своего рода).
Пример:
input
20:00:00
04:00:00
output
08:00:00

input
12:34:56
14:36:22
output
02:01:26

Не могу понять алгоритм,ну никак?

П.С:Вольво сразу предупреди если я что-то не то сделал,может не учёл правила unsure.gif

Автор: volvo 17.02.2007 23:09

Переводи стартовое и финальное время в секунды, отнимай одно от другого, и результат - опять в часы:минуты:секунды...

Возможен один исключительный случай - если результат будет отрицательным. Сам догадаешься, что надо сделать в этом случае?

Автор: Perfez 17.02.2007 23:13

Цитата
Переводи стартовое и финальное время в секунды, отнимай одно от другого, и результат - опять в часы:минуты:секунды...

Спасибо,но я об этом ,знал. smile.gif Только не говори что если знал почему не сказалюЯ именно и на это зацикливаюсь:Вот например с этим примером:
Цитата
input
20:00:00
04:00:00
output
08:00:00

??? blink.gif wacko.gif

Автор: volvo 17.02.2007 23:14

Я тебе сказал, что есть исключительный случай? Вот он... Тебе надо догадаться, что делать...

Автор: мисс_граффити 17.02.2007 23:19

нюанс, который не совсем понятен по условию: ограничения.
максимальное оставшееся время - сутки? или сколько? дата же не задана...

Автор: Perfez 17.02.2007 23:19

(20:00:00-04:00:00)+((24:00:00-20:00:00)/2)
Может это??? wink.gif


Добавлено через 1 мин.

Цитата
The first line of input contains the current time in hh:mm:ss format (hours, minutes, seconds). The
hours will be between 0 and 23 (inclusive) and the minutes and seconds between 0 and 59.
The second line contains the time of the explosion in the same format.

Нужен ли перевод?

Автор: мисс_граффити 17.02.2007 23:21

зачем такие сложности?!
подумай, в каком случае время будет отрицательным... сразу станет понятно, что надо сделать

ага, нашла:

Цитата
The time Borko wants is at least one second and at most 24 hours

Автор: Perfez 17.02.2007 23:25

ну,незнаю...когда есть дело АМ и РМ?То есть если стрелка перейдёт 12... blink.gif

Добавлено через 58 сек.
Что нашла?

Автор: мисс_граффити 17.02.2007 23:26

AM -> PM у тебя отслеживается: 11:00 -> 13.00
разница, как видишь, положительна.

про ограничения.
вот это:

Цитата
максимальное оставшееся время - сутки? или сколько? дата же не задана...

Автор: Perfez 17.02.2007 23:27

прибавлю к получившемуся отрицательному 24:00:00??? blink.gif

Автор: мисс_граффити 17.02.2007 23:29

Да.
Смотри: когда происходит переход на новые сутки, мы считаем, сколько осталось старых суток и сколько возьмется от новых, т.е.:
(24:00-20:00)+04:00=(04:00-20:00)+24:00

Автор: Perfez 17.02.2007 23:31

урррррррррррраааааааааа!спасибо good.gif

Добавлено через 15 мин.
В чём проблема?


type
time=array [1..3] of byte;
var
a,b:time;
c,d:string[8];
e,f:int64;
Procedure Strong(var c:string[8]; var a:time);
var
x:byte;
y:integer;
Begin
For x:=1 to 2 do
Begin
Val(Copy(c,1,Pos(':',c)-1),a[x],y);
Delete(c,1,Pos(':',c));
End;
Val(c,a[3],y);
End;
Begin
ReadLn©;
Strong(c,a);
ReadLn(d);
Strong(d,b);
If c=d then WriteLn('00:00:00');
e:=(b[1]*3600+b[2]*60+b[3])-(a[1]*3600+a[2]*60+a[3]);
If (a[1]>=b[1]) and (a[2]>=b[2]) and (a[3]>a[3]) then e:=e+24*3600;
Write(e div 3600,':');
e:=e mod 3600;
Write(e div 60,':');
Write(e mod 60);
End.


blink.gif wacko.gif






Добавлено через 14 мин.
Может проверите?.Всё готово:

type
time=array [1..3] of byte;
var
a,b:time;
c,d:string[8];
e,f:int64;
Procedure Strong(var c:string[8]; var a:time);
var
x:byte;
y:integer;
Begin
For x:=1 to 2 do
Begin
Val(Copy(c,1,Pos(':',c)-1),a[x],y);
Delete(c,1,Pos(':',c));
End;
Val(c,a[3],y);
End;
Begin
ReadLn©;
Strong(c,a);
ReadLn(d);
Strong(d,b);
e:=(b[1]*3600+b[2]*60+b[3])-(a[1]*3600+a[2]*60+a[3]);
If (a[1]>=b[1]) and (a[2]>=b[2]) and (a[3]>=b[3]) then e:=e+24*3600;
If e div 3600<10 then Write('0',e div 3600,':')
else Write(e div 3600,':');
e:=e mod 3600;
If e div 60<10 then Write('0',e div 60,':')
else Write(e div 60,':');
If e mod 60<10 then Write('0',e mod 60)
else Write(e mod 60);
End.


yes2.gif






Добавлено через 2 мин.
Не нужно проверять он прошёл все тесты=по-моему... wink.gif

Автор: volvo 18.02.2007 0:10

Цитата
В чём проблема?
Какая из них? У тебя в программе НЕ одна проблема... Первая из них: ты уверен, что в FPC индексация строк начинается с 1? smile.gif

Добавлено через 1 мин.
P.S. Это же самое делается в 3 строки (с использованием такого мощного компилятора - тем более) ...

Автор: Perfez 18.02.2007 0:14

Kak?
smile.gif

Автор: Perfez 18.02.2007 0:37

Обо что споткнулся я?


Эскизы прикрепленных изображений
Прикрепленное изображение

Автор: volvo 18.02.2007 1:14

Цитата
Обо что споткнулся я?
smile.gif
Вот об это:
If (a[1]>=b[1]) and (a[2]>=b[2]) and (a[3]>=b[3]) then e:=e+24*3600;
А если так:
с = '20:00:00' и d = '04:10:10', то что ты получишь в результате, подумай...


Автор: Perfez 18.02.2007 1:21

.

Автор: volvo 18.02.2007 1:45

Я ж показал тебе: условие не выполняется, а увеличивать E все равно надо... Ответы читай внимательно, все равно готового решения не будет...

Автор: Perfez 18.02.2007 1:55

Absolute True Solution:
Абсолютное Правильное Решение:


Добавлено через 2 мин.
Вольво:Извини до этого не видел твои посты unsure.gif и я не искал готовых решений rolleyes.gif


Прикрепленные файлы
Прикрепленный файл  natrij1.pas ( 661 байт ) Кол-во скачиваний: 225