Автор MikeMirzayanov, 11 лет назад, По-русски

Всем привет!

7 марта в 18:00 начнется первый квалификационный раунд чемпионата VK Cup 2015!

Раунд продлится 24 часа, такая продолжительность выбрана для того, чтобы все нашли себе удобное время для участия. Квалификационный раунд, как и все предстоящие раунды, требует отдельной регистрации. Регистрация станет доступна 7 марта в 00:00, она будет открыта на протяжении всего раунда.

При регистрации на любой из квалификационных раундов состав вашей команды фиксируется и не подлежит дальнейшей модификации. Вы не сможете в будущем добавить или удалить члена команды. Пожалуйста, перед регистрацией убедитесь, что у вас нет желания изменить состав. Состав команды не сможет быть изменен, даже если вы отмените регистрацию на квалификационный раунд.

Если вы пока не уверены в текущем составе команды, то не регистрируйтесь на предстоящий раунд. Если вы не будете участвовать в первой квалификации или не пройдете по ее результатам в Раунд 1, то вы сможете попробовать свои силы во второй квалификации.

Чтобы пройти в Раунд 1, вам надо принять участие хотя бы в одной из квалификаций. Из каждой квалификации в Раунд 1 проходят все команды с положительным числом баллов, которые набрали не меньше баллов, чем команда на 500-ом месте.

Пользуясь случаем поздравляем всех девушек-участниц с праздником. Спасибо вам за весну!

Во время квалификации задачи тестируются системой только на претестах, а системное тестирование состоится после окончания раунда. Обратите внимание, что претесты не покрывают все возможные случаи входных данных, поэтому тщательно тестируйте свои программы! Взломов, падения стоимости задач во время квалификации не будет. Время сдачи задач не будет учитываться, однако будут учитываться штрафные попытки.

Категорически запрещается публиковать где-либо условия задач/решения/какие-либо мысли и соображения о них до окончания раунда. Запрещено обсуждать задачи с кем-либо кроме вашего сокомандника. Будьте честны, пусть в Раунд 1 пройдут сильнейшие!

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

Если вы впервые участвуете в соревнованиях подобного рода, ознакомьтесь с одной из задач 158A - Next Round квалификационного раунда чемпионата VK Cup 2012, а также примерами ее решения на разных языках программирования:

Желаем удачи и удовольствия от решения задач!

UPD 1: Ура! Квалификация 1 закончена, все решения протестированы. В Раунд 1 квалифицированы все те команды, которые набрали 1500 баллов или больше. Таких команд оказалось 789, поздравляем их всех! Те из вас, кто не набрал 1500 баллов могут не расстраиваться, ведь 14 марта стартует Квалификация 2.

UPD 2: Опубликован разбор задач.

Пользуясь случаем поздравляем всех девушек-участниц. Спасибо вам за весну!

  • Проголосовать: нравится
  • +117
  • Проголосовать: не нравится

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +19 Проголосовать: не нравится

А название потом менять можно будет?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

а можно пожалуйста ссылку на правила соревнований? а точнее список языков=)

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +14 Проголосовать: не нравится

Другие раунды будут рейтинговыми?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -16 Проголосовать: не нравится

"7 марта в 18:00 начнется первый квалификационный раунд чемпионата VK Cup 2015! Раунд продлится 24 часа, такая продолжительность выбрана для того, чтобы все нашли себе удобное время для участия." Очень странно выбрали время старта. Вот очень странно, но кажется что 8 марта днем писать квалификацию мало кто захочет. Лучше б в 9 утра стартовали.

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится +3 Проголосовать: не нравится

как я понял, писать можно обе квалификации.

т.е. есть если одну команда напишет скверно( или очень скверно), но при этом ьаллов во второй наберет достаточно чтобы пройти в первый раунд, она проходит? и аналогично в том случае, если завалит вторую квалификацию, но затащит первую?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

За задачу начисляются баллы, только если пройдены все тесты?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Регистрация команды — это и есть регистрация в первом Раунде? Или нужно дополнительно регистрироваться?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +5 Проголосовать: не нравится

А если мне больше 23 лет, могу я написать раунд вне конкурса?

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    Нет, но я не думаю, что внеконкурсное участие в Квалификации носит существенную ценность. Большая часть раундов Чемпионата будет открыта для внеконкурсного участия. Ждем!

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Сколько времени на решение?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Создала команду из 1 человека (себя :)), но почему-то не могу зарегистрироваться. При регистрации в выпадающем списке "Выберите команду" не вижу моей команды. :(

Это только у меня такая проблема? Как ее решить?

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    Вы, видимо, просто создали команду в интерфейсе создания команд. Надо было создать ее в рамках VK Cup — для этого нажмите "Зарегистрировать команду" в меню раздела справа или в крупную ссылку-кнопку "Зарегистрироваться" в посте-анонсе Чемпионата.

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -12 Проголосовать: не нравится

Сделайте раунд рейтинговым!

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится -7 Проголосовать: не нравится

Емае, что с задачей А не так? UPD: проверилось

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +1 Проголосовать: не нравится

Сказано, что регистрация открыта в течении всего раунда. Где она?

»
11 лет назад, скрыть # |
Rev. 3  
Проголосовать: нравится +11 Проголосовать: не нравится

It's so similar :) link Table shows accepted problems as wrong answer.

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится +3 Проголосовать: не нравится

У нас у единственных нет доступа к соревнованию? UPD: всё работает

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +1 Проголосовать: не нравится

Регистрация станет доступна 7 марта в 00:00, она будет открыта на протяжении всего раунда.

Почему нельзя зарегистрироваться на раунд с момента его начала, т.е. с шести часов?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +1 Проголосовать: не нравится

А регистрации то нет. Может это часть соревнования :D?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +1 Проголосовать: не нравится

Почему выдаёт "Нет доступа на просмотр соревнования?", при клике на "Квалификация 1" ?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Да вы не одни

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    Регистрация открыта, регистрируйтесь на раунд в любое время вплоть до его окончания.

    • »
      »
      »
      11 лет назад, скрыть # ^ |
       
      Проголосовать: нравится 0 Проголосовать: не нравится

      Доступ открылся, регистрация где?

      В моем профиле ссылка на соревнование со словами "соревнование уже идит"

      В самой квалификации задачи отсылать нельзя, т.к. команда не зарегистрирована.

      Я б принт скрин приложила, да не могу загрузить его. Где регистрироваться на квалификацию?

      • »
        »
        »
        »
        11 лет назад, скрыть # ^ |
         
        Проголосовать: нравится 0 Проголосовать: не нравится

        Сначала регистрируете команду в Чемпионат. Затем, если хотите участвовать в Квалификации 1, то и на нее. При регистрации на Квалификацию команда "замораживается" и не подлежит редактированию в дальнейшем.

        Приглашение зарегистрироваться на Квалификацию 1 есть на странице сорвенований http://mirror.codeforces.com/contests, выделенное красным. Для регистрации на раунд необходимо уже иметь команду для участия в VK Cup 2015.

    • »
      »
      »
      11 лет назад, скрыть # ^ |
       
      Проголосовать: нравится 0 Проголосовать: не нравится

      как регистрироватся на раунд?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +57 Проголосовать: не нравится

Чисто из любопытства, по какому параметру сортируются в таблице команды с одинаковыми баллами и местом?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Я помоему зарегистрировалься на VK CUP (команда — 3,14) но на соревнование 1 на дает отослать решение , можете помочь ?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Системное тестирование случится сразу по окончанию квалификации или же через некоторый (возможно, очень большой) период времени?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -9 Проголосовать: не нравится

Извините, но почему мы не можем отправлять решение задач? У нас выходит такая надпись. Хоть и мы сделали регистрацию.. => ("Для просмотра страницы вы должны быть зарегистрированы на соревнование");

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

I've registered the team, but when I'm trying to register on contest, it isn't listed. What should I do ?

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится +5 Проголосовать: не нравится

Разбалловка: 500-1000-1500-2000

Кол. команд, которые решили(10:35 мск): 808-864-155-207

Вот так устроен наш мир :)

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -22 Проголосовать: не нравится

А задачу D вообще на чём-то кроме С++ и Java реально сделать? Что-то складывается ощущение, что ограничение времени там выставлено исключительно под компилируемые языки.

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится +32 Проголосовать: не нравится

    Это нормальная практика в соревнованиях по программированию. Если ставить ограничения так, чтоб на всяких Python и Ruby можно было сделать, то на C++, возможно, будут проходить по времени неоптимальные решения. А под каждый язык делать свои ограничения довольно утомительно.

  • »
    »
    11 лет назад, скрыть # ^ |
    Rev. 2  
    Проголосовать: нравится +26 Проголосовать: не нравится

    Из раздела про языки программирования:

    Не гарантируется, что задачи будут иметь решения на каждом из представленных языков (особенно это касается скриптовых).

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится +24 Проголосовать: не нравится

    Да ладно, а на C#, хасекле, Go, Scala и паскале не заходит? Кроме того, наверняка можно упихнуть на PyPy. Или под "чём-то кроме С++ и Java" понимаются всякие php и javascript'ы? (при этом не удивлюсь, если на js тоже впихивается)

    • »
      »
      »
      11 лет назад, скрыть # ^ |
       
      Проголосовать: нравится 0 Проголосовать: не нравится

      Ну на PyPy не пробовал, а на Python3 у меня не уталкивается и до сих пор ниодного решения на Python не вижу. Хотя не исключаю неоптимальность моего кода, просто напрягает, что у всех остальных тоже оптимальности на питоне не хватает, а на плюсах что-то у многих влетает.

      • »
        »
        »
        »
        11 лет назад, скрыть # ^ |
         
        Проголосовать: нравится +34 Проголосовать: не нравится

        Это потому что большинство опытных участников пишут на C++ или Java. Возможно, упихивающие на питоне просто упихивают что-то не то. Отправлять решения на Python3, когда есть PyPy, — довольно странно, он же сделан как раз для улучшения производительности.

        Когда контест будет в дорешивании (и если у меня будет время) — попробую впихнуть на PyPy, посмотрим, зайдёт ли.

      • »
        »
        »
        »
        11 лет назад, скрыть # ^ |
        Rev. 2  
        Проголосовать: нравится +113 Проголосовать: не нравится

        Это было непросто, но я таки впихнул на питоне, даже с двукратным запасом: 10210744

        Из интересных наблюдений: дерево интервалов слишком тормозное, надо использовать дерево Фенвика (не ожидал, что в Питоне оно будет настолько быстрее); встроенная сортировка питона ооочень тормозная.

        Что же касается ваших решений, которые показываются на вкладке "Статус", — то они просто неправильные (потому что работают за 5000002 операций, такое ни на каком языке даже близко не зайдёт).

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Результаты сразу будут (в пределах пары часов)? Или через длительное время?

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится -116 Проголосовать: не нравится

Нафига до последнего надо было тянуть? :) извиняюсь за большой размер

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Предчувствую, что много решений D упадет

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Так как вы решаете C и D

(извините мой русский)

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    после считывания входных данных уменьшим количество порций по тем заказам, которые Поликарп смог разобрать.

    найдем блюдо, которое может закончиться раньше всех, для этого в обновленном массиве а найдем минимум, при условии,
    что данное блюдо никому не выдавали, после первого недовольного пассажира, пусть его индекс - i
    
    посчитаем количество нерасслышанных заказов до первого недовольного - sumBefore
    и количество всех нерасслышанных заказов - sum
    
    для того что-бы j-ое блюдо могло закончиться до получения Поликарпом необходимо и достаточно, что бы выполнялось:
    
    a[j]+a[i]<= sum  или (a[j]<=sumBefore и j блюдо никто не заказывал после первого недовольного пассажира )
»
11 лет назад, скрыть # |
 
Проголосовать: нравится +1 Проголосовать: не нравится

Арррргх, отдебажил D через 40 секунд после окончания раунда... Когда откроют задачи для посылок?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +8 Проголосовать: не нравится

мне одному хочется расчленить авторов задачи С?

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Расскажите пожалуйста идею в D... Надо ли там строить дерево отрезков и если надо, то как?

  • »
    »
    11 лет назад, скрыть # ^ |
    Rev. 2  
    Проголосовать: нравится +3 Проголосовать: не нравится

    да, я строил, дерево минимумов.

    очевидно, что для отрезка [l1,r] ответ не превышает ответ для [l2,r] пр условии l1<=l2 поэтому заведем структуру данных (дерево отрезков минимумов), в которой будем хранить для i-го элемента расстояние до ближайшего равного ему справа (до которого мы уже дошли) тогда ответ на запрос будет минимум на отрезке [l,r] мы будем идти по массиву слева на право обновляя структуру, пусть мы сейчас на i-ой позиции проверим, может ли текущее число улучшить результат для какого-нибудь отрезка, при условии, что оно правое равное для этого смотрим индекс предыдущего равного данному пусть он равен j, тогда ближайшее правое равное j-му находится в i-ой позиции, значит нужно обновить элемент а для вывода ответа на входной запрос проверяем, не находимся ли мы в крайней точке какого-нибудь запроса, если да, то выводим минимум на отрезке этого запроса

    UPD: есть более краткие решения, но я их не знаю))

    • »
      »
      »
      11 лет назад, скрыть # ^ |
      Rev. 2  
      Проголосовать: нравится 0 Проголосовать: не нравится

      Можно используя то же ДО на минимум написать так: Обработка запроса [l, r]:

      1. Возьмем минимум на всем отрезке.

      2. Если минимум(min1) больше длины отрезка -> ответ = -1, иначе перейдем к шагу 3.

      3. Возьмем минимум(min2) на отрезке [l, r — min1].

      4. Если min2 == min1 — это ответ. Иначе вернемся к шагу 2, присвоив min1 = min2

      Сложность : m * log^2(n)

      • »
        »
        »
        »
        11 лет назад, скрыть # ^ |
         
        Проголосовать: нравится +8 Проголосовать: не нравится

        Как интуитивно можно доказать, что отрезок [l, r] будет каждый раз уменьшаться в 2 раза?

        • »
          »
          »
          »
          »
          11 лет назад, скрыть # ^ |
          Rev. 2  
          Проголосовать: нравится 0 Проголосовать: не нравится

          на каждом шаге либо отрезок уменьшается в 2 раза, либо минимум увеличивается в 2 раза. То есть всего может быть максимум шагов. Классная идея, надо ее запомнить.

        • »
          »
          »
          »
          »
          11 лет назад, скрыть # ^ |
           
          Проголосовать: нравится 0 Проголосовать: не нравится

          Худший тест для такого алгоритма:

          n m
          1 2 3 4 5 .. n/2 n/2 .. 5 4 3 2 1
          1 n/2
          1 n/2
          ...
          

          соответственно минимумы начиная от центра слева направо :

          1 3 5 7 9 11 .. n-1
          

          Если суть алгоритма перенести на этот массив, то он становится таким: берем cur = a[0]; подходит — круто, не подходит, берем cur = a[cur]; и проверяем снова. Соответственно, проверим мы только 1, 3, 7, 15, 31, 63 .. ячейки, из-за нечетности минимумов.

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится +4 Проголосовать: не нравится

    Я решал бинпоиск + спарстейбл))

  • »
    »
    11 лет назад, скрыть # ^ |
    Rev. 2  
    Проголосовать: нравится +2 Проголосовать: не нравится

    А можно корневую. Подсчитаем для каждой пары блоков i, j лучшую пару чисел, в которой первое число входит в блок i, второй в j. Получим для каждого блока (i) массив A, где A[j] -- лучшая пара из чисел, которые лежат в блоках i и i + j соответственно. Далее построим для каждого массива массив минимумов на префиксах, чтобы узнавать лучшую пару на нескольких подряд идущих блоках. После всего этого останется выделить последовательные блоки в каждом запросе, на них отвечать за O(sqrt(n)), пробежавшись по ним всем и раздвинуть границы, добавляя по 1 элементу (это очень просто, если для каждого элемента подсчитать ближайший слева и справа такой же).

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    Я решил двумя sparsetable на минимумы. Сначала на всем отрезке L;R ищем пару с самым левым правым концом (пусть L1;R1), потом на отрезке R1;R ищем правый конец пары с минимальной длиной, он и есть ответ. Обе пары наверное надо проверять на то, что они внутри запрашиваемого.

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

У кого-нибудь D по памяти падала? и почему?

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится 0 Проголосовать: не нравится

    У меня падала. Из-за того что в массиве изначально не было одинаковых элементов и построение дерева отрезков рекурсивно уходила вглубь бесконечно.

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится -6 Проголосовать: не нравится

    Ну, можно было поизвращаться. Сперва для каждой позиции найдем r — минимальное расстояние до такого же элемента слева. Потом выпишем все пары (r, pos) в возрастающем порядке. Считаем все запросы [left, right]. Далее фиксированная пара (r, pos) является "хорошей" (ответ r) для всех запросов с условиями left <= pos — r, right >= pos. На такие запросы можно дать ответ r и выкинуть их из рассмотрения. По сути нужно удалять прямоугольные интервалы. Для этого заведем дерево отрезков с подмассивами в вершинах (строим по запросам). Получится очень похоже на сжатое двумерное дерево. Всего точек будет O(nlogn), удаление каждой за O(logn). Итого: O(n*logn) по памяти, O(n*logn*logn) по времени. ЭТО ПРИМЕР КАК НЕ НАДО ДЕЛАТЬ. По памяти падает. Даже построить дерево не получается на макстестах.

    • »
      »
      »
      11 лет назад, скрыть # ^ |
      Rev. 2  
      Проголосовать: нравится 0 Проголосовать: не нравится

      Неправда. Ровно это решение у нас зашло "всего" за 2.25 секунды и 190 мб на плюсах (на джаве даже не пытался это отправлять на контесте)

    • »
      »
      »
      11 лет назад, скрыть # ^ |
       
      Проголосовать: нравится 0 Проголосовать: не нравится

      На самом деле можно поддерживать массив min_left, в котором на i-й позиции находится запрос с самой левой границей среди тех, у кого правая граница равна i, а вместо "удаления прямоугольных интервалов" каждый раз делать итеративно так:

      1) пусть left — минимум на отрезке [r;n] в массиве min_left.
      2) если left > pos - r, закончить с текущей парой (r, pos).
      3) иначе узнать, какой отрезок мы только что нашли, удалить его, и обновить min_left в соответствующей позиции.
      4) вернуться к шагу 1)

      Поиск минимума и обновление можно делать с помощью дерева отрезков. Это работает за O((n + m)logn) времени и O(n + m) памяти.

  • »
    »
    11 лет назад, скрыть # ^ |
    Rev. 2  
    Проголосовать: нравится 0 Проголосовать: не нравится

    deleted

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится 0 Проголосовать: не нравится

Я правильно понял, что все, кто решил первые две задачи с первого раза прошли квалификацию?) UPD: Уже прочитал=)

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -20 Проголосовать: не нравится

задача В сама перезасылалась 2 раза, хотя мы ничего не делали, у кого-нибудь еще было такое?

»
11 лет назад, скрыть # |
Rev. 3  
Проголосовать: нравится 0 Проголосовать: не нравится

deleted

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится -15 Проголосовать: не нравится

Посылка на контесте: 10197994 TL28

Такой же код под GNU C++11 после контеста:10209490 АС

Такой же код под GNU после контеста: 10209797 AC

Тот же код переписанный на сканф/принтф после контеста: 10209570 АС

Тот же код с cin.tie(0) после контеста: 10209660 AC

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

может кто-то объяснить идею этого краткого решения

http://mirror.codeforces.com/contest/522/submission/10201772

  • »
    »
    11 лет назад, скрыть # ^ |
    Rev. 2  
    Проголосовать: нравится +11 Проголосовать: не нравится

    Сортим запросы по R, для каждого храним prev[i], когда идем по r-ам обновляем prev[r] на величину r — prev[r], таким образом у нас выходить за правую границу не будет.

    Ответ находим деревом отрезков

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +4 Проголосовать: не нравится

А когда будет разбор? И будет ли вообще?

  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится +2 Проголосовать: не нравится

    в комментах довольно подробно расписали задачи C и D. На счет A и B: A решается с помощью map<string, int> как два пальца об асфальт, из условия вытекает, что репосты будут в форме дерева. Достаточно хранить для каждого человека глубину в дереве. B — нахождение двух максимумов. С шириной фотографии все понятно, когда iый фотографирует, то ширина будет равняться sumw — w_i, где sumw суммарная ширина. А для высоты фотографии требуется хранить два максимума, т.к. высота при фотографировании iым человеком будет равняться hmax1 если iый человек не максимального роста и hmax2 в ином случае. Допускается что hmax1 == hmax2.

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится 0 Проголосовать: не нравится

deleted

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

А как будет проходить не квалификационные раунды? Интересует именно временной промежуток, т.к. живу на часовом поясе МСК + 6

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится +5 Проголосовать: не нравится

Можно ли посмотреть полный набор тестов? В тесте №6 задачи 3 у меня неверно считает строку 309 выходного файла... Вот тут

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +48 Проголосовать: не нравится

Я не понимаю Зачем некоторым людям таким, как Progmeistars, участвовать на кф раундах, если каждый такой раунд сводится к попрошайничеству решений у других участников (в основном из Казахстана). В этот раз я не поленился и думаю нашел доказательство его катания. До этого иногда я тоже находил, но решил отписаться впервые. Вот решение, которое он выпросил, 10204660. Удалив все #define и изменив название нескольких переменных, у него получилось такое решение 10205743. Сохранив при этом почерк. К счастью решение у обоих упало :) Народ Хватит ему давать катать!

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

Дальше прошли 791 команд вместо 500. Это очень много. Будет интереснее.

»
11 лет назад, скрыть # |
Rev. 2  
Проголосовать: нравится 0 Проголосовать: не нравится

Можно ли посмотреть полный набор тестов? В тесте №6 задачи 3 у меня неверно считает строку 309 выходного файла... Вот тут

»
11 лет назад, скрыть # |
 
Проголосовать: нравится +42 Проголосовать: не нравится

В задаче C в условии сказано, что 2 ≤ m ≤ 100 000. Но в тесте №6 присутствует такой тестовый случай:

1 3
1 2 3
  • »
    »
    11 лет назад, скрыть # ^ |
     
    Проголосовать: нравится +67 Проголосовать: не нравится

    Спасибо, есть такое. Тесты исправил, пореджаджил все попытки. Теперь в Раунд 1 проходит 789 команд, а не 788 :) Справедливость восстановлена!

»
11 лет назад, скрыть # |
 
Проголосовать: нравится -50 Проголосовать: не нравится

tqven deda sheveci me C s piroba normalurad dadevit bozishvileboo tqvena

»
11 лет назад, скрыть # |
 
Проголосовать: нравится 0 Проголосовать: не нравится

"VK Cup 2015 — Round 1 (online mirror, Div. 1 only)" — втором дивизиону участвовать нельзя? Даже при условии, что в команде есть человек из первого дивизиона?