Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Потрепаться";
Текущий архив: 2005.03.27;
Скачать: [xml.tar.bz2];

Вниз

Воскресная задачка :D   Найти похожие ветки 

 
Alexis ©   (2005-02-27 11:28) [0]

Решил и я выложить задачку, которая imho, заслуживает внимания...

Два друга договорились встретиться между 12 и 13 часами(включительно). Если первый приходит и не застает другого, то он ждет 16 минут, а если второй приходит и не застает первого, то он ждет 36 минут.
Какова вероятность, что они встретятся?

Удачи :D


 
GuAV ©   (2005-02-27 12:16) [1]

0,34(8)


 
GuAV ©   (2005-02-27 12:52) [2]

То есть нет, 1 - 0,34(8) = 0,65(1)


 
Alexis ©   (2005-03-03 17:36) [3]

Ага :)
В другой раз потяжелее выложу :D


 
default ©   (2005-03-03 17:53) [4]

"Дан массив, содержащий некоторую перестановку чисел 0.. N-1
Отсортировать его за О(N) операций и с O(1) доп. памяти."
Вот ещё, её MBo как-то давал
несложная


 
Uncle Archi ©   (2005-03-03 20:38) [5]

default ©   (03.03.05 17:53) [4]
По условию, решение просто:

For i:=0 to n-1 do write(i," ");

Если просто перестановка чисел.


 
Uncle Archi ©   (2005-03-03 20:51) [6]

В тему. Попробуйте решить:
"Рассмотрим выражение 1n+2n+3n+4n. На сколько нулей заканчивается его десятичная запись?"
(http://acm.timus.ru/problem.aspx?space=1&num=1295)

А решение лежит на поверхности.
Стоит только попробывать.


 
default ©   (2005-03-03 21:14) [7]

Uncle Archi ©   (03.03.05 20:38) [5]
так низя
надо в массиве переставлять
Uncle Archi ©   (03.03.05 20:51) [6]
1n+2n+3n+4n=10n, умножение на 10 даёт один нул + число нулей в n
n считаю натуральным


 
Uncle Archi ©   (2005-03-03 21:22) [8]

default ©   (03.03.05 21:14) [7]
Сори, 1n+2n+3n+4n читать как 1^n+2^n+3^n+4^n
А тебе лень на оригинал взглянуть, на Тимусе, там ведь правильно написано.


 
MBo ©   (2005-03-04 09:00) [9]

>default ©   (03.03.05 17:53) [4]
Чтобы не возникало соблазна просто a[i]:=i сделать, можно условие, если не ошибаюсь, так сформулировать:

Массив заполняется так:
a[i]:=2*i+Random(2);
затем выполняется перестановка (случайная перетасовка)
Отсортировать за О(N) операций и с O(1) доп. памяти.

При этом для каждого значения известен целевой индекс, но не наоборот.


 
default ©   (2005-03-04 18:54) [10]

Uncle Archi ©   (03.03.05 21:22) [8]
не сильно сложно доказать, что на конце может быть не более двух нулей
далее можно попытаться не сильно сложным методом найти нужные ограничения на n


 
GrayFace ©   (2005-03-04 19:22) [11]

MBo ©   (04.03.05 9:00) [9]
Вот тупой алгоритм, удволетворяющий условию:
var i,j,k:integer;
begin
 for k:=0 to n-2 do
 begin
   i:=a[k];
   while (i>k+1) or (i<k) do
   begin
     j:=i;
     i:=a[j div 2];
     a[j div 2]:=j;
   end;
 end;
end;


 
Uncle Archi ©   (2005-03-04 20:54) [12]

default ©   (04.03.05 18:54) [10]
Повторюсь: "Стоит только попробывать".
Нужно правильное решение ?


 
default ©   (2005-03-04 21:45) [13]

Uncle Archi ©   (04.03.05 20:54) [12]
нет
у меня в голове пока только достаточно трудоёмкий путь
но решение будет эффективно если это дело до конца довести
пару условных операторов с недолго вычислимыми(думаю) выражениями...
может в вашем решении подход другой?
более вычислительноёмкий...
намекните немного


 
default ©   (2005-03-04 23:33) [14]

Uncle Archi ©   (04.03.05 20:54) [12]
вообщем понятен принцип
как я говорил максимум в конце может быть два нуля, это можно доказать
для того чтобы данное выражение оканчивалось хотя бы на один нуль оно должно делиться нацело на 10
[1+2^n+3^n+(2^n)*(2^n)]/10=
0.1+2^(n-1)*0.2+2^(n-1)*0.2*2^n+(3^n)/10
в столбцах 1,2,3,4 расположены дробные части слагаемых при
соответствиющих n
n =                1      2      3      4  далее идёт повтор
0.1              0.1     0.1    0.1   0.1  
2^(n-1)*0.2      0.2     0.4    0.8   0.6  
2^(n-1)*0.2*2^n  0.4     0.6    0.4   0.6
(3^n)/10         0.3     0.9    0.7   0.1
Дроб.часть         0       0      0   0.4
суммы      
отсюда видно что при каждом четвёртом значении n начиная с n=1
наше выражение будет содержать минимум один нуль
теперь аналогично нужно сделать для деления на 100, и дальше
алгоритм написать не будет составлять труда
можно, естественно, то что я написал тут и формально изложить


 
default ©   (2005-03-04 23:34) [15]

малость съехало...


 
default ©   (2005-03-04 23:37) [16]

отсюда видно что при каждом четвёртом значении n начиная с n=1
наше выражение  не будет содержать ни одного нуля на конце иначе - минимум один нуль на конце


 
default ©   (2005-03-04 23:39) [17]

начиная с n=4
P.S. сори за невнимательность:)


 
default ©   (2005-03-05 22:30) [18]

Uncle Archi ©   (04.03.05 20:54) [12]
покатит?


 
Uncle Archi ©   (2005-03-06 10:16) [19]

default ©   (05.03.05 22:30) [18]
Почти, только я это делал без вычислений, я просто посчитал для первых 17 n значение суммы,
а задача решается 4мя строчками:


If n=5 then Write(2)
 else If n mod 4=0 then Write(0)
   else If n mod 4=3 then Write(2)
     else Write(1);


 
GrayFace ©   (2005-03-07 18:57) [20]

GrayFace ©   (04.03.05 19:22) [11]
Ошибка вышла небольшая.
var i,j,k:integer;
begin
for k:=0 to n-2 do
begin
  i:=a[k];
  while (i>k*2+1) or (i<k*2) do
  begin
    j:=i;
    i:=a[j div 2];
    a[j div 2]:=j;
  end;
end;
end;



Страницы: 1 вся ветка

Форум: "Потрепаться";
Текущий архив: 2005.03.27;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.49 MB
Время: 0.032 c
9-1104390790
макс
2004-12-30 10:13
2005.03.27
Glearthskydome


1-1110655753
Evgenos
2005-03-12 22:29
2005.03.27
ListBox.Color проблема


1-1110894372
Dysan
2005-03-15 16:46
2005.03.27
компиляция проекта но без vcl


9-1104646617
netreym
2005-01-02 09:16
2005.03.27
OpenGL загрузка моделей


1-1110595554
zsv
2005-03-12 05:45
2005.03.27
Ассоциации





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский