1

Likes in Posts and Comments

 1 year ago
source link: https://codeforces.com/blog/entry/98347
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client
By MikeMirzayanov, 16 months ago, In English

Hello.

Here's a small improvement for posts and comments. Likes can now be specified in their markup. Maybe this will be useful for organizing some kind of polls or collecting feedback.

Here are some examples:

Markup
Use square brackets instead of round
Result
Simple likes widget
(likes:1)

1287

Same keys means same likes widgets
(likes:2)
(likes:2)

865


865

Same keys and different groups can be used for exclusive choices
(likes:3,option1)
(likes:3,option2)

524


522

Yes, I know that this feature can be improved. I would prefer that we try to use it a little and understand what exactly is missing the most. Maybe we need to implement the fully functional polls.

Let's do a small survey using the new feature.

  1. What is your age range?

  2. Tabs or spaces?

  3. Have you had covid??

  4. Lately, there have been a lot of meaningless blogs on Codeforces. Is it worth strengthening measures to fight against them?

    • yes definitely:

      1044

    • rather yes, but not necessarily:

      2518

    • rather no, I read some of them:

      326

    • no definitely:

      128

16 months ago, # |

Rev. 4  

0

Please change "you" to "I" in last point : "no definitely, you just don't understand them". Thanks.

  • 16 months ago, # ^ |

    Rev. 2  

    +31

    Fixed. Do you like the changes?

    595

16 months ago, # |

Can we please have an faq section which is more visible/relevant ?

It's annoying how after every contest there's a comment about java code giving TLE due to Arrays.sort() and unordered map giving TLE.

One feature I'd like to see is wiki section where the many educational blogs written on Codeforces can be seen. Currently whenever I have to see/read about a new topic (example -> segment tree) . I have google segment tree codeforces . This shows all the segment tree related blogs on codeforces which include many useless ones. The blogs would be chosen based on upvotes or any other reliable source.

Also thanks for the features.

  • 16 months ago, # ^ |

    So much support for a list/catalog/wiki of tutorial blogs. Only a few days ago I found out that I had missed an interesting blog about convolutions because I happened to not check the blogs during the 24 or so hours this blog was in Recent Actions. It would be awesome if I could just open the list of tutorial blogs and start reading up on the first thing I don't know. Also as someone who sometimes writes educational blogs it's kinda demotivating to see my blog just disappear into the void after it gets buried under "please debug my code", "rule about third-party code is changing", announcements of old rounds and "someone cheated on Telegram".

    The only issue is preventing this place from being overrun with spam and low-quality tutorials. My suggestion is to simply allow only masters and above (or whatever rating limit feels appropriate) to add blogs to such a page.

    • 16 months ago, # ^ |

      I've been facing these issues myself as well. You need to constantly monitor recent actions for high quality blogs, lest it gets flooded with spam blogs. The main issue seems to be the fact that "blogs" being the only top-level communication unit forces them to perform all sorts of functions, and useful stuff for some purposes is just spam for other purposes.

      Adding a page with links to good tutorial blogs would definitely be a good idea (and it would be great if it could be kept persistent with all history rather than just a sliding window like recent actions). Perhaps this can be done as a separate section on the EDU page as well, idk.

16 months ago, # |

Rev. 2  

+77

Now I can beg for likes without begging for contribution:

I request likes

369

BTW the widget is displayed as usual text when previewing comments, is that intended?

  • 16 months ago, # ^ |

    I don't see internet points increasing, I upvote.

16 months ago, # |

Rev. 3  

+19

Thanks Mike for this amazing feature!

60

orz Mike for this astonishing feature!

148

  • 16 months ago, # ^ |

    Forgiving my dark mind, I laughed so hard every time seeing "orz Mike" xD

16 months ago, # |

Rev. 3  

+1

BIT

70

Segtree

208

  • 16 months ago, # ^ |

    There's a bit of a bug: when I revert to previous revisions and back to current, the markup doesn't work anymore.

16 months ago, # |

Rev. 2  

+13

Do you want Favourite Blog Entries to be collapsible?

  • yes definitely:

    86

  • rather yes, but not necessarily:

    2

  • rather no, I read all of them:

    2

  • no definitely:

    1

16 months ago, # |

Seriously?! Almost 1/5th of you prefer spaces over tabs!

  • 16 months ago, # ^ |

    I am actually not sure what exactly is asked there. Auto-replacing tabs with spaces is more or less a standard practice, so which of the two is this?

16 months ago, # |

Rev. 2  

+3

like update works a little weird (when u like smth, the counter jumps on 2-4 likes up)

  • 16 months ago, # ^ |

    Could be possible that multiple people may have pressed it concurrently.

    17

16 months ago, # |

Division 3 rounds

82

Division 2 rounds

144

Educational Rounds

88

Division 1+2 rounds

123

Unrated rounds

58

  • 16 months ago, # ^ |

    i Liked Them all :_:

    • 16 months ago, # ^ |

      Rev. 2  

      0

      You can like all options

16 months ago, # |

Rev. 2  

-15

It is decidedly so.

6

Signs point to yes.

10

Better not tell you now.

2

Outlook not so good.

2

16 months ago, # |

I like it except that the icon is so similar to the like button Facebook used sometime.

16 months ago, # |

Late editorial after contest:

4

Fast editorial after contest:

15

Editorial during contest:

137

  • 16 months ago, # ^ |

    Rev. 4  

    +12

    Late editorial after contest:

    3

    Fast editorial after contest:

    15

    Editorial during contest:

    8

    Editorial before contest:

    138

16 months ago, # |

Thanks, Mike. This new feature is so great! However, maybe codeforces will have more strange blogs uses this feature but not related to CP. Trash "Likes" blogs may become more.

16 months ago, # |

Rev. 2  

0

When you vote likes in a blog at HOME page and then refresh the page, the vote by you is not rendered :(

However when you open the blog page, the like is shown correctly.

This a bug, or it is intended?

UPD: It seems that this issue has been fixed. Thanks all the developers! :D

16 months ago, # |

Rev. 8  

+60

Predict how many upvotes this comment will earn:

84

  • 16 months ago, # ^ |

    omk orz

16 months ago, # |

Rev. 3  

-10

Are you having a great Day

Yes :

86

No :

83

  • 16 months ago, # ^ |

    When I voted Yes, it automatically voted No.

    Maybe I am having a great&bad day in the same time.

    • 16 months ago, # ^ |

      Yeah because i didnt use widget where both have differnt groups. Dont take it personally :-:

16 months ago, # |

Rev. 4  

+1

Unlike voting (the one that affects our contribution), these are revertible at least. Also, we can leave a like to our own widget too.

16 months ago, # |

What you prefer most for static RMQ

  1. Segment Tree

    110

  2. Sparse Table

    62

  3. Sqrt decomposition

    7

  4. Binary Indexed Tree

    6

What you know of them?

  1. Segment Tree

    162

  2. Sparse Table

    125

  3. Sqrt decomposition

    103

  4. Binary Indexed Tree

    110

Are you surprised to know that BIT can be used for arbitrary RMQ not only prefix?

  1. Yes

    87

  2. No,I already know that before

    51

  • 16 months ago, # ^ |

    Are you surprised to know that BIT can be used for arbitrary RMQ not only prefix?

    I really wonder how to solve it. May you tell me?

    Thanks in advance.

    • 16 months ago, # ^ |

      Rev. 3  

      +9

      http://ioinformatics.org/oi/pdf/v9_2015_39_44.pdf

      I already implemented query in logn and update in log^2 n but I didn't implement update in logn successfully until now :(

      • 16 months ago, # ^ |

        Rev. 4  

        +5

        and the query is 4X times faster than recursive segment tree and as fast as iterative segment tree but I think its easier to implement but there is no use of that when I can't implement the logn update (because I am noob)

        if any one can share his implement I will be thankfull :)

      • 16 months ago, # ^ |

        Rev. 2  

        0

        I try implementing the RMQ BIT (queries and updates in $$$O(\log N)$$$) though I am not sure if my implementation is fully correct. I have tried it on the following problems and it seems to be working fine.

        • 16 months ago, # ^ |

          Your code is not logN update.

          You can see that easily as you have two nested loop any of them have logN complexity.

          I tried these problems already when I was trying to implement and get AC but wasn't able to persuade my self so I generated alot of random tests and compare BIT code with a recursive segment tree.

          And the res is the query operations is so fast around 4X times faster than segment tree but update is so slow as its make 10X time than segment tree there can be two reasons that we didn't see the diffrence in these problems.

          1. Not provided a test with alot of update query.

          2. Provided a test like that but small const factor and a fast query cover that.

          • 16 months ago, # ^ |

            Rev. 2  

            +5

            You can see that easily as you have two nested loop any of them have logN complexity.

            But the inner for loop is not reset on every iteration of the outer for loop (the pointer i and j can only go up in the tree), so it should be $$$O(\log N)$$$ right? Similiar to how two pointer is $$$O(N)$$$.

            for (int i = 0, j = 0; i < n; ++i) {
              while (j <= i && ...) {
                ++j;
              }
              ...
            }
            • 16 months ago, # ^ |

              Oh I am wrong.

              Yes Yes, you are right I miss read the position of j=p-1

              I thought it was in the increment part but I notice now that it is in the initialization part.

              Thanks for the implementation I will revise it carefully now :")

  • 16 months ago, # ^ |

    Are you surprised to know that BIT can be used for arbitrary RMQ not only prefix?

    This is not so surprising if you consider what segments a BIT maintains.

    A BIT maintains the solid segments on the right while it is "missing" the dotted segments (that do appear in the segment tree). Notice that the missing segments are exactly the ones you would get if you added another BIT on the reversed array. So it seems intuitive because with two BITs, you at least have the necessary information to answer range minimum queries.

    And from this image it's also not hard to derive how to answer the queries. You jump left on the normal BIT and jump right on the reversed BIT until you meet. This visits essentially the same things as an iterative segment tree, so a similar constant is also plausible.

    • 16 months ago, # ^ |

      That what I was able to do.

      the all problem is update query which my implementation wasn't run corectly so I can only use two get min query on every node two update it with total (logn node)*(logn query for each node) =log^2(n)

      I undrestanded the update process corectly but I wasn't able to implement it sadly :(

  • 16 months ago, # ^ |

    Are you surprised to know that BIT can be used for arbitrary RMQ not only prefix?

    For minimum query on prefix, is it possible to perform updates using arbitrary values?

    • 16 months ago, # ^ |

      Yes, and not only for RMQ on prefix but also for arbitrary RMQ

      • 16 months ago, # ^ |

        Could you explain how? From what I've read from cp-algorithms, we can only do the update if the new value is not greater than the current value.

16 months ago, # |

Rev. 2  

-13

tabs: 1K

27

spaces: 277

15

WTF? I can't believe there are so many people in this community who prefer tabs over spaces. It must be the other way around.

A tab could be a different number of columns depending on your environment, but a space is always one column.

  • 16 months ago, # ^ |

    Rev. 2  

    +57

    A tab could be a different number of columns depending on your environment, but a space is always one column.

    Exactly. If someone prefers 4 space and you prefer 2, when they use tab you both can see the code in own preferred way. With space you don't have that option. That may be the reason many people prefers tabs.

    • 16 months ago, # ^ |

      What if you're looking at code on someone else's screen?

16 months ago, # |

Maybe there is a little bug: the marks are not visible when I refresh the page. But it works when I click it and removed from liked.

16 months ago, # |

Rev. 2  

+60

No way to see exact number of likes when it crosses 1K. This might be an issue when number of likes for two options are close and both cross 1K.

  • 16 months ago, # ^ |

    Rev. 6  

    +2

    QAQ

    5

    QwQ

    2

    OvO

    2

    (>_<)

    46

    • 16 months ago, # ^ |

      Use [] in place of ()

      • 16 months ago, # ^ |

        Thanks!

        14

      • 16 months ago, # ^ |

        [>_<]

16 months ago, # |

Rev. 2  

+10

Are u able to implement the like : yes

24

Or no

13

16 months ago, # |

How does this work if you edit your post/comment?

16 months ago, # |

scanf & printf :

6

cin & cout :

47

fread & fwrite :

0

write custom read() function :

3

16 months ago, # |

exactly one of them tells a lie!

  1. you will like this one.

    4

  2. you will like the third one.

    1

  3. you will like this one.

    53

  4. you will not like this one.

    7

16 months ago, # |

Rev. 2  

+51

Maybe we can change the '1K' to something like '1.06K'. This way the number of likes will be clearer as 1.99K and 1.01K are probably shown as '1K' now.

btw orz Mike

20

16 months ago, # |

I see only plain text when I go through previous revisions of comments, and it doesn't get fixed when I go back to the recent revision. Also, the icon is not rendered in comment previews.

16 months ago, # |

Rev. 5  

+11

When you roll back a revision(click ←) and redo it, you'll find like system failed to be loaded.

6

BTW in spite of these bugs this is still a great system:)

16 months ago, # |

My choices are messed up, it shows the choices I didn't vote for yesterday.

16 months ago, # |

1.) Like #5 only if it is Thursday

4

2.) Ignore #1 if you are not currently liking #4

4

3.) Upvote my comment

4

4.) If the time in minutes is an odd number, Ignore #6

4

5.) If you haven't liked an odd number of statements, you must go back and obey enough rules to make your count of obeyed rules a multiple of five.

4

6.) Ignore #2 if the number of times you have liked #4 and number of upvotes on this comment is a Lucas Number

4

  • 16 months ago, # ^ |

    If you like one you will like all of them.

    Use it correctly.

16 months ago, # |

Rev. 2  

0

P.S.This is a test. (Upd: It works!

(Original

qwq

4

| qvq

4

qaq

4

QwQ

3

QAQ

3

Solve the following two-sat problem:

No.1 is 0 or No.6 is 1

No.2 is 0 or No.3 is 1

No.2 is 1 or No.4 is 0

No.3 is 1 or No.4 is 1

No.3 is 0 or No.1 is 1

No.1 is 0 or No.2 is 0

No.6 is 0 or No.5 is 0

No.4 is 0 or No.5 is 1

No.1

8

No.2

4

No.3

7

No.4

3

No.5

2

No.6

5

16 months ago, # |

0-based indexing

36

1-based indexing

9

15 months ago, # |

Need a dislike button.


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK