Loading collection data...
Collections are a way for you to organize kata so that you can create your own training routines. Every collection you create is public and automatically sharable with other warriors. After you have added a few kata to a collection you and others can train on the kata contained within the collection.
Get started now by creating a new collection.
There are 20000 JS tests in total, your code handles about half of them, I have run it several times - the result is
10_000 - 12_000
. To be honest, I haven't looked closely at your code and can't tell you exactly what the problem is, but your algorithm needs to be improved. However, before you change anything, maybe you can add caching for some “heavy” calculations (if there are any and it is possible), it might work.Okay. That makes it a little clearer. Thank you. I may have more questions).
I'm not sure what your question is.
Amines are tricky, because they can be named in two different ways. Either "ramifications+amine", or "main-chain+ramifications+amine".
So, you have from 1 to 3 carboned chains on the N, and either all of them are named as ramifications, or one can be named as a "main chain". Here, the dimethyl part is after what looks like the main chain (ethan) so they aren't on that chain but on the N. The 1 refers to the position of the N on the main chain (since we are in "way 2" aka
[ramifications on main chain]main-chain-(pos-suffix)
and here, the suffix is[dimethyl]amine
, kinda).So you end up with what's on the left of that name in the description:
I got to the section
Amines, phosphines, arsines:
and here I have another question. In the description for it saysRamifications of ramifications
that there should be a pattern like this.But in the description I see this example -
ethan-1-[dimethyl]amine
, can you please explain this, ramifications does not end with...radical + “yl”
?Oh, duh! You actually found a bug: the list of prefixes isn't up to date and still contains
anoyloxy
instead ofoyloxy
...I'll update that, thx. (edit: done)
Thanks for the quick reply and for breaking down this example. It all makes sense. Now I realized what the mistake was. The list of prefixes in
python
is missingoyloxy
and I just copied it and didn't double-check it)). Perhaps you could update it and be able to add that prefix or is that the way it's designed?The name is valid.
Is that enough?
Or is there “garbage” in the formulas and such cases should be ignored?
I remember almost nothing from chemistry class and it's a real pain to keep everything in my head, so many rules. So, I started writing a tokenizer and got stumped, I can't figure out how to parse it:
This is where my tokenizer breaks down, because I can't figure out what to match the part after
yn
with. Perhaps (probably) I'm missing something from the description, I'd be grateful if you could help me.p.s. Don't judge strictly:))).
This comment is hidden because it contains spoiler information about the solution
This comment is hidden because it contains spoiler information about the solution
.
This comment is hidden because it contains spoiler information about the solution
I would of course love to solve in
python
as well, however it seems to me that time has passed. This kata is practically 10 years old and now IMHO, it is not 1kuy. Maybe you should just do something based on this task, but heavily refined (I mean a completely new publication)? For example, make it a performance task, add:JOIN
,LEFT JOIN
,RIGHT JOIN
,DISTINCT
,CASE
,EXISTS
.... These are just as examples of what could be implemented and improve this kata.By the way as a performance option, if there will be large data volumes and different sized tables, the right
JOIN
will make a difference. If you do it nicely and add significant differences from this kata, I think it would be a great new kata.p.s. I wonder if anyone has responded on Discord though? What kind of response did you get?
Roger that. Thank you!
Loading more items...