IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> задача про натуральное число
Sofo4ka
сообщение 24.10.2006 19:14
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 12
Пол: Женский

Репутация: -  0  +


задуманно натуральное число х.известны три числа- остатки от деления этого числа 3,5,7 - i,j,k соответсвенно. найти Х
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 25.10.2006 14:56
Сообщение #2


Гость






Цитата
Невероятно smile.gif

Потому, что некорректно smile.gif Ты же не инициализируешь Find и C1 заново при каждой итерации, следовательно, у тебя в первом случае показывается время одной итерации, а во втором - время ВСЕХ... Вот так - корректнее:

uses windows, crt;
var
i, j, k: Integer;
c1, c2, c3, a, b, c,
p, global: Integer;
find: boolean;

T: dword;

begin
clrscr;

write('i = '); readln(i);
write('j = '); readln(j);
write('k = '); readln(k);

T := gettickcount();


global := 0;
repeat
find := false;
c1 := 0;
while (c1 < maxint) and not(find) do begin
a := c1 * 3 + i;
c2 := 1;
while (c2 < maxint) and not(find) do begin
b := c2 * 5 + j;
if b > a then break;
c3 := 1;
while (c3 < maxint) and not(find) do begin
c := c3 * 7 + k;
if (c > b) or (c > a) then break;
find := ((a = b) and (a = c));
inc(c3);
end;
inc(c2);
end;
inc(c1);
end;

inc(global);
until global = 900000;

if find then writeln(a)
else writeln('No found !');
writeln('klem1:: Time = ', gettickcount() - T);


T := GetTickCount();

global := 0;

repeat
for p := 1 to maxint do
if (p mod 3 = i) and (p mod 5 = j) and (p mod 7 = k) then break;

inc(global);
until (global = 900000);

writeln('Result = ', p);
writeln('klem2:: Time = ', gettickcount() - T);


readln;
end.


Эскизы прикрепленных изображений
Прикрепленное изображение
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 31.07.2025 1:26
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"