Язык этого раунда — Kotlin. Kotlin (Ко́тлин) — статически типизированный язык программирования, работающий поверх JVM и разрабатываемый компанией JetBrains.
Вот вам пример простейшей программы, которая выводит сумму двух чисел:
fun main(args: Array<String>) {
val (x, y) = readLine()!!.split(' ').map(String::toInt)
println(x + y)
}
Для того, чтобы познакомиться с языком мы предлагаем вам почитать следующие материалы:
- https://en.wikipedia.org/wiki/Kotlin_(programming_language)
- https://kotlinlang.org/docs/reference/
- http://try.kotlinlang.org/ — осторожно, чтение с консоли во web-IDE не разрешено
- введение в Kotlin на русском
- и Google к вам в помощь!
Вы можете отдельно выкачать компилятор языка версии 1.0.1 по ссылке http://s.codeforces.com/files/kotlin-compiler-1.0.1.zip Для запуска компилятора без IDE вам нужна установленная JRE (виртуальная машина Java), её можно найти по ссылке http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html
Пароль для архива с IDEA (IDE с поддержкой Kotlin из коробки): c8bf9dd9b91ad9ff Сами ссылки на IDEA — чуть ниже или на официальном сайте https://www.jetbrains.com/idea/download/
Удачи!
====
UPD: Вы можете заранее выкачать пакет разработчика (извините, 300 МБ). На самом деле можно будет обойтись и без него — будет доступен запуск на Codeforces и в 18:30 выложим вариант покомпактнее.
OS | |
---|---|
Linux | http://s.codeforces.com/files/683-linux.7z |
Windows | http://s.codeforces.com/files/683-windows.7z |
Mac OS | http://s.codeforces.com/files/683-macos.7z |
Все архивы запаролены, пароль будет опубликован в 18:30.
========
16 июня в 19:00 (московское время) вас ждет Surprise Language Round #8. Напоминаю, что это необычное развлекательное соревнование. Задачи можно будет сдавать лишь на одном языке, а каком — пока секрет.
Таким образом, предполагается что за время раунда участники могут познакомиться с языком и сдать на нем несколько несложных задач. Язык раунда будет анонсирован за 30 минут до старта раунда. В этом же время (или даже чуть раньше) мы опубликуем архивы с инструментами для написания программ на этом языке.
Я рад анонсировать, что лучшие 20 участников получат клевую эксклюзивную футболку, а еще 10 штук будут случайным образом разыграны среди всех тех, кто решил хотя бы три задачи.
Правила проведения раунда:
- Соревнование будет нерейтинговым для всех участников.
- Индивидуальное соревнование по правилам ACM ICPC: положение в результатах определяется количеством решенных задач, при равном количестве — набранным штрафным временем. Изначально штрафное время участника равно 0, при каждой сданной задаче оно увеличивается на время, прошедшее с начала контеста, + 20 минут за каждую неудачную посылку до отправки правильного решения. Решение считается правильным, если оно прошло все тесты из предопределенного набора; правильно ли посланное решение, становится известно сразу. Взломов чужих решений нет.
- В раунде будет 6-10 задач, примерно отсортированных по сложности, и 2 часа на их решение.
- Решения задач принимаются только на одном языке, который будет объявлен за 30 минут до старта контеста.
- Пожалуйста, в начале контеста перечитайте этот пост целиком: в нем появится объявление языка, рекомендации по установке компилятора (в интерфейсе контеста будет доступен запуск программы онлайн) и полезные ссылки на документацию. В остальном изучение языка — дело рук самого участника. Для решения задач вы можете использовать любые ресурсы (но не совместное участие); ограничиваться документацией, приведенной в посте, не обязательно.
Удачи!
First SLR I'm eligible to participate in in 5 years.
9 am on a weekday in my time zone.
:-(
Take the morning off?
It is awesome that Surprise Language Round comes back since the previous Surprise Language Round was 21 months ago.
Unless you count VK Cup 2015 Wildcard Round 1 15 months ago and VK Cup 2016 Wildcard Round 1 2 months ago, which both used SLR format and both had parallel rounds open to everybody.
Or do you feel nostalgic about the name "Surprise Language Round" itself? :-)
In fact, this contest is interesting, and I want to participant it.
My dream is going to get a T-Shirt. Can you pray for me?
Okey ....
I Can Pray. But I really can't Prey ....
Oh,sorry. but I can beat you.
A moment of silence for our dear departed friend, English.
Spray the Helix Fossile!
Hi, I am new to CodeForces competitions, and this will be first one. Will the programming language be something completely new(like an unknown language)? Or will it be like a custom/madeup language?
thanks pimaster314
It will be an existing but esoteric programming language. You can see the languages used in previous surprise language rounds in the link below.
http://codeforces.net/blog/entry/13750
Tshirt! registered. :)
Really excited related to this contest, it will be fun to know a completely new language. Contest Like these makes coding and codeforces interesting.
Exclusive! Exclusive!. How this is exclusive?! Can we see it?
Not gonna lie, I registered for the T-shirts.
Lol. I updated my Tshirt size, just in case ;-)
LoL. Reminds me of the time when I hurried up in updating my Tshirt size after I won one. I never actually cared because I never though I'll get one ;)
I never updated my T-shirt size on baylor site so I recieved an XL T-Shirt.
I switched it with my team mate and he still doesn't know about it why did he got a XL T-shirt xD .
lol I did the same xD
!!!
T-shirts
Может кто-нибудь переложить архив для linux на amazon или ещё куда-нибудь? У меня что-то очень плохой канал для скачивания, 5 KB/s
http://hdd.tomsk.ru/desk/jpixsnjf
Или вот на диске https://yadi.sk/d/eSHNtd7ysYZrv
Наслышан. Пойду-ка я футбол лучше посмотрю
Да язык то говорят неплохой, но я честно говоря ожидал чего-то более экзотического и менее джаваподобного :)
NO!!I haven't finished downloading it yet. Is there any way to get it faster?
Kotlin. Очень разочарован. Думал будет что-то необычное и интересное, как в предыдущих SLR
Однако не может не радовать то, что после этого скорее всего kotlin будет доступен на обычных раундах!
First link, the wikipedia one, is broken I can't click on it, only copy and paste to address bar works.
which compiler should i select in custom test?
Чет это не сюрприз никакой. Во-первых, уже больше двух лет прошло с Kotlin Challenge, во-вторых, этот язык некоторые уже и просто в продакшене юзают, а в третьих — да пишешь просто точно так же, как на джаве, и оно работает.
Ну вот участвовал я в Kotlin Challenge — не совсем как на Java (конечно, много общего). Кроме того Kotlin Challenge был для русскоязычной аудитории, а на Codeforces сейчас это даже не большинство.
Я думаю очень слабое пересечение сообщества Codeforces и тех, кто в продакшне его использует.
Этот раунд следует воспринимать как способ познакомиться с языком в соревновательных условиях. Не хотите — не участвуйте, уверен — кому-то будет весело.
Да, и я тоже надеюсь, что будут и необычные языки в подобных раундах в будущем.
Я тоже участвовал в Kotlin Challenge — и единственное, что выучил — как многомерные массивы создавать. Все остальное то же самое. Я, конечно же, поучаствую: идея уже запущена, три задачки — и домой :)
Кстати, шаблончики можно взять с https://www.go-hero.net/
Про три задачки-то наврал)
Чет я увлекся :) Решил 8 на работе, после восьмой — сразу домой...
Девятая подоспела just in time!
Спасибо за раунд!
Поясните, пожалуйста, общественности, когда стоит ждать Kotlin в числе доступных языков на обычных соревнованиях на сайте?
Пока в выпадающем списке языков отсылки пробного тура Kotlin-a не видно: http://codeforces.net/gym/101021/submit
На сегодняшнем раунде уже будет — регистрируйтесь и участвуйте!
Только что посмотрел — нету его
Kotlin? It seems that the next SLR is going to have C++ as the only language:) Btw, it surely will be a great surprise:)
+1 This is so similar to Scala :/
There isn't much of a surprise.
+1
They might be choosing Kotlin for introducing some harder task to SLR, but Kotlin is way too common (and too sane). Quite different from old SLRs by Nickolas.
Well, next time you can do this for Rust, or Elixir, or whatever.
Yeah, rust sounds pretty interesting.
Kotlin is too common to be fair. People who are familiar with the language (or even with Java) has a clear advantage.
Дальше будет 1С.
still cant figure out how to read input >_>
Me too :(
this can solve the first problem,but i dont know how to read a string :(
Why var y = readLine()
and not:
val y = readLine()
As I understand, we can't change the value of val
Кажется года 4 назад на полуфинале в Питере давали игрушечный тест на Kotlin в качестве его рекламы, вот ведь неожиданность )
I am unable to compile my source code from given compiler. Any help?
I guess you forget to add header files
Аааргх. Я пишу не первый SLR, но только для котлина уже полчаса не могу найти ни одного способа считать и распарсить инпут, который бы скомпилился.
Особый сок — вспомнить про котлин.челленж, найти пост на хабре, увидеть в нем решение одной из задач, положить его в "запуск" и увидеть, что оно не компилится. То ли мне больше не стоит заниматься программированием, то ли все-таки лыжи не едут.
Я начал экспериментировать с тем вводом, что приведён в анонсе. Он, как оказалось, умеет считывать строку либо в несколько переменных, либо в массив. В итоге в C у меня вот такие костыли:
Но они хотя бы работают...
Можно же просто написать
В задаче С в одной строке записано и количество элементов и сам массив.
Можно проще, достаточно дропнуть первый элемент:
+забавное соображение: даже если его не дропнуть, на симметрическую разность это не повлияет — если она реализована как "добавить, если нет, и удалить, если есть".
Видимо, я пошел другим путем и завалил две посылки, прежде чем увидел, что первое число — количество элементов.
Но его же.. А давно он там появился?
Да вроде в 18:30, со всеми остальными материалами. Мне тоже этот пример из шапки очень помог )
Я прямо перед стартом чуть выше написал сайт со статистикой GCJ — https://www.go-hero.net/. Можно было там найти любое решение на Kotlin. Я именно так и сделал — можешь посмотреть мои посылки. Собственно, там точная копия моего джавовского шаблона.
I cant find any courses that tell me how to read a string or read input one by one:(
How to use the compiler? The IDE told me that I did not have Project SDK.
Random winners of 10 t-shirts will be determined using the following code (testlib is used). The code will be executed with two parameters in the command line: number of participants with at least 3 problems and penalty of the lowest among them.
That was one of the most interesting contests I've ever participated btw.
Many congratulations to t-shirt winners (1-20):
And random winners (yes, 12 t-shirts because of ties):
I wish I had 187th rank rather than 87th :/
Lel I wish I had 26 instead of my 25 :D
Aww! Missed the T-shirt, but it's always fun doing SLRs. Wish they are held more frequently.
MishaPrigara took 117 place, not 177. Check it please
Oh, I missed. Thanks, fixed. I'll ask for exta t-shirt for MishaPrigara.
The contest was awesome Mike, Thank you.
About the t-shirt, I didn't receive an email or any sort of thing. So, please email me at [email protected]
Thanks.
This code crashes if n ≤ 30.
I just hacked MikeMirzayanov!
O(N lg K) was supposed to pass on G?
I got TLE on #21 :/
You meant H? Not sure about O(NlgK), solved it with O(N).
Yeah H, how in O(N).
I used binary jumping for N lg K.
Iterate over every student, build cycles for them — it is O(N)
For every cycle get shift = K % cycle_len, for every student in cycle get his new book from (i — shift) pos in cycle (if lesser than 0 += cycle_len). It is O(N) too.
Solved it with O(NlogK): 18526851. I'm guessing your solution is slower than mine because of large array.
Ah! I made the mistake of storing the whole precalc table :/ Should have done it on the fly.
Ah, placed 25, so close.
What is wrong with this for C?
I get Runtime Error on test 17: 18529037
You should try to write simpler code.
http://codeforces.net/contest/683/submission/18525180
MUCH simpler
Much simpler
I get it that this isn't the most elegant way to do it, but I had no idea about these
contains
functions, still what is wrong with my code? The thing I did was mostly straightforward, dont understand why it would get RE :/Probably, there were two consecutive space between numbers. You could filter them out or just don't convert a string to int: 18525267
To add to what others have said, you read 2 chars per number, but the numbers can range from -1000 to 1000. So even if the input does not have consecutive spaces, you can end up with
stringerA
starting with a space, which then causes this exception. Even if it didn’t throw this exception though, you would still get a wrong answer because you’d parse the numbers wrongly.Round is very interesting and educational.
Thank you.
I submitted solution for E, got TLE, so I decided to rewrite code from Java. I copy-pasted the Java code to the Kotlin file and IDEA asked: "Do you want to convert it to Kotlin code?". I clicked "Yes" and this way I got E accepted without writing a lot of Kotlin code. I wish I knew the copy-pasting rule from the beginning of the contest.
Yea, sounds cheaty from the perspective of non-Java participant :)
Definitely sounds like that. Before copy-pasting I was prepared for a long process of manual conversion from the language I knew into the language that I didn't know, so that wouldn't be so different if the source language was C++ (or any other language). The process would probably be errorprone and given the size of the SetWithCount class my initial thought was that the chances of successful conversion are slim but I had no better idea. After learning that one can convert code from Java to Kotlin I wrote solution to G in Kotlin without using Java. What's the fun of writing Java solution when it is a Kotlin contest?
Anyway, the "conversion from Java to Kotlin" message was the big "WTF?!!! I was browsing the Reference manual for two hours, while I could have just written everything in Java and then convert?", so I guess the language wasn't the only surprise for me in this contest:)
Heh, before this round, I've just thought, "the author seems to be Mike, so it may be a way to battle-test a new language for regular rounds".
Will Kotlin be available for common rounds now as well?
Did someone used "Convert from java" button of http://try.kotlinlang.org/#/Examples/ ?
Do I get something wrong about J, or it is easier than I?
In J you don't have to find a minimal path, so you can just blow every single wall and exit. 100k actions is more than enough for that.
As a developer working on Kotlin at JetBrains, I'd like to present my solutions for today's problems (except H), maybe they will be of use for someone. (UPD: I did not take part in the round.)
Your B solution looks great. I see that I could have just sorted the students instead of using HashMap<Int, MutableMap<String, Int>>. Such an overkill:) I had a lot of trouble with trying to use Map.computeIfAbsent, because IDEA kept coloring it red, and I finally gave up and used temporary variables. What I wanted to do:
Is there a way to use computeIfAbsent (or getOrElse or getOrPut or something else) to achieve the same effect without using temporary variables?
computeIfAbsent
is not available inkotlin.Map
currently because it breaks variance of Map's generic type parameters. I believe this is being discussed and worked on currently (link).I don't think there's a nice way to write this without using temporary variables :) I can only suggest something like the following:
You don’t need the last
capitalize
call in F, do you?You're right, it's not needed. I've updated the solution. Thanks!
For problem I, I noticed something strange in some accepted solutions:
I thought we needed to minimize the number of pushes. It seems they are printing three pushes, while the optimal solution is only one push.
Can you please share the submission id?
This is mine: 18529203
Seems that it minimizes answer's length :)
Seems like the checker actually accepts any correct sequence at least one of them exists.
One such solution: 18527894
Oh, it seems it is my bug. Thanks. And I did it 12 years ago!
The problem is from Saratov local contest of 2004.
BTW, it is fixed. We will not rejudge contest solutions, but all other solutions have been rejudged.
Regarding the language, I have one feedback comment for now.
When I want a specific construct, I usually Google for it. For the things in the standard library (for example, set or regular expressions), the first link usually invites to read the official API Reference. Its pages list all methods, but I didn't find any single example each time I got there. And it is hard(er) to learn using a construct without an example readily available. So, I usually scrolled the Google results down to find the first link to StackOverflow, and it helped.
The point is, for a new user, it would be nice if the examples came on the first link from a respective Google search. If that link is usually API Reference, it would be nice to have examples right in the API Reference.
В течение и после соревнования у меня, кажется, глючила таблица результатов. В какой-то момент я видел себя на первом месте в таблице, но, если на неё посмотреть сейчас, очевидно, что я никогда не был первым. В районе часа после начала соревнования в таблице внезапно появилась целая куча народа или успешных посылок, которых раньше в ней не было — причём посылок, датированных более ранними временами; и я сразу сильно упал. И даже после конца соревнования, когда таблица мне предложила перезагрузить страницу, я её перезагрузил и видел себя на 11-м месте и только Егора с минусом в I прямо подо мной. А сейчас я на 12-м, а минус в I есть у целых двоих человек прямо подо мной.
Ну а язык, как уже говорили, хотелось бы поэкзотичней. По Котлину уже было специальное соревнование, рекламировавшееся и на Кодфорсах. К тому же там выше говорят, что есть даже несколько рабочих конвертеров с Джавы… Но всё равно спасибо — для меня это вышел первый раз пописать на Котлине.
Моя посылка с 11 места тестилась еще примерно минуту после окончания соревнования. И ее не было видно, пока она не дотестилась. (может быть, имеет смысл помечать такие посылки вопросиками?) С остальными, видимо, так же.
А. Это объясняет, почему в конце соревнования таблица не сразу обновилась. Было бы хорошо помечать вопросиками, да. Да хотя бы где-нибудь на видном месте иметь пометку о том, что ещё не всё дотестилось, было бы хорошо. (Или она уже есть, но не на очень видном месте, а я про неё забыл?)
Но во время соревнования всё равно было как-то странно. Уж первым-то я себя точно не должен был видеть! Если другие люди раньше послали — причём вон насколько раньше! то их посылки должны были бы раньше протеститься, по идее.
Может стоит переименовать такие раунды в surprise motherfucka language round?
Kotlin was indeed a fun language (no pun intended)
А можно как-нибудь узнать статус отправки футболок? Мне еще не доехала, а другому человеку из моего города доехала уже неделю назад (если он не врет), и это как-то странно.
MikeMirzayanov
Дорешивание сломалось: нет возможности выбрать язык, решения не отправляются. Наверное, при апгрейде языкового пакета что-то слетело.