Enigma27's blog

By Enigma27, history, 5 weeks ago, In English

If you haven't read the camp announcement yet, check it out here: blog

Updates

Since the ICPC prelims will be held again, and due to the short notice, it might be difficult for teams to arrange travel. Therefore, we will be selecting teams based on one of the following criteria:

1. Your past performance in ICPC Regionals/AWC/WF

2. Average rating of your team (~1800+ for Div 2 and ~2100+ for Div 1, with some advantage for 2nd/3rd year students and IOI candidates)

3. Having solved at least 4 problems in the recent prelims round.

Selection Notification:

Selected teams will receive an email confirmation from today onwards (until November 20th).

Div 1 Teams:

  • Please acknowledge your selection and send your arrival/departure times. This information will help us book your accommodation and arrange travel from New Delhi Airport/Railway Station to the camp location.

  • Provide the usernames of your teammates who want their names printed on your camp t-shirts.

  • Submit a cool team motto (similar to what you might write on your regionals photo).

Div 2 Teams:

  • In addition to everything mentioned above for Div 1, you will receive a payment link to confirm your slot in the camp.

Div 1 vs. Div 2 Preference:

If you believe you were selected for Div 1 but would prefer Div 2, or vice versa, please contact us directly via DM, reply to the selection email, or comment on this blog post.

Registration:

Register here: goforgold website or fill out this form

Note:

  • Div 2 has limited slots remaining. We will select teams who meet the criteria on a first-come, first-served basis.

  • We have already shortlisted around 6-7 Div 1 teams and expect some IOI participants to join as well. To ensure a faster discussion pace and cover more ideas, we will limit Div 1 participants to around 30. This means only 2-3 slots are left.

Full text and comments »

  • Vote: I like it
  • +11
  • Vote: I do not like it

By Enigma27, history, 5 weeks ago, In English

All the best to all registered teams for ICPC India 2024 Preliminary Contest.

Attaching an excerpts from my team's codebook (it may help you during the contest).

If you haven't gone through the GoForGold initiative , read this blog and visit the website.

Do register for camp : fill the interest form

UPDATE

Since ICPC prelims will be organized again and it will be difficult for the teams to arrange for travel in short duration thus we will be selecting teams on the basis of :

1. Your past performance in ICPC Regionals/AWC/WF

2. Average rating of your team (~1800+ for div2 and ~2100+ for div1 with some advantage for 2nd/3rd year and IOI candidates)

3. If you have solved >=4 problems in the recent prelims round.

Note : This is a non-profit invite only camp to enhance the CP culture in india. We have more initiative lined up so even if you think you won't be in top50 prelims teams then also register. The selection criteria will be similar to IOITC where if you are in 2nd/3rd year then you will be given a little bit more preference even with lower rank/rating.

For the teams with rank > 50 in prelims, do register in div 2 if your team's average rating is >= 1700-1800 and in div1 if your average team rating is >= 2100.

The camp is also open for IOI participant. Some of them are already coming and also volunteering in the camp (like our orz evenvalue)

Codebook credit : hitman623 , TooDumbToWin, DeshiBasara, _shanky, Enigma27

Full text and comments »

  • Vote: I like it
  • +24
  • Vote: I do not like it

By Enigma27, history, 7 weeks ago, In English

Announcing GO For Gold Campaign (Powered by NST)

Greeting Indian ICPC contestants !!


India is home to some of the brightest minds in the world, and our potential is undeniable. Yet we have a long way to go regarding Competitive Programming at ICPC. While Indian teams have shown great promise by reaching to World Finals but getting a medal is still something which we are still trying to achieve. But with our current talent and potential, we can and will achieve this.

At NST, we believe the potential exists, and what’s needed is structured guidance, consistent mentorship, and a platform to hone these skills under expert supervision. That’s why we created Go For Gold, a program focused on building a culture of competitive programming excellence in India, not just for one college or a year, but as a long-term initiative to make India a top contender at ICPC.

The Go For Gold Program, with the support of NST, a neo-age college program, is an institutional effort to propel competitive programming in India. With the initiative, we want to ensure India wins its first medal in the next 3 to 4-year horizon. This program aims to be the first to build a more robust, competitive ecosystem of top programmers from college and industry. We invite every student, mentor, and institution to join hands in this mission. Your involvement is not just appreciated. It's crucial to India’s rise in the global competitive programming arena.

India needs a deep culture of competitive problem. We want to make younger kids aware of Competitive Programming early. This complex undertaking would require all the hands to come together. Our initiative of Go For Gold will cover strategies to reach the programming and competitive problem culture from the early years of schooling.

NST believes that by building a vibrant programming community with proper support and guidance, we can make a change at the country level by creating a competitive culture of programming and problem-solving.

We would like to do more rigorous camps with top trainers, not just at the elite level but right from class 6th for IOI in parallel to IOITC but for larger audiences.

With IIT Kanpur announcing six seats to Computer Science and Engineering from IOI and IMO selection, the broken pipeline between IOI and ICPC will get better enhancing our chances to get a medal.

Announcing GO FOR GOLD Camp

We are hosting a 7 days offsite invite-only bootcamp to train this year aspirants for Asia West and World Finals. The contest will happen in 2 divisions

  • division 1 (ex ICPC Finalist teams and top-10 teams from prelims)
  • division 2 (top 30-40 teams from the prelims and ex-Asia west Finalist teams)

From last few years we are solving 5 problems in WF (our best rank was in 2012 where IIITH team solved 6 problems).

The div1 camp will focus on 4th — 6th problems of WF so that this year our team can solve first 5 problems fast and get enough time to solve the 6th problem (aryanc403's team solved 5 problems in 4:40 in 2021, if we could reduce this time then we can solve the 6th problem)

The div2 camps will focus on Last few problems of Asia West and first 4 problems of WF.

Fees

  • The camp is completely free for ex Finalist teams top-10 prelims teams

  • The training/material/logistics will be free for div2 and we will only charge a token amount (INR 8000 per person only for booking stay).

Are you still feeling unsure? Here is the trainer list, which we are still adding.

  1. ⁠AmirReza Pourakhavan (Arpa), 2x ICPC WF, IGM
  2. ⁠Shreyan Ray (Dominater069), IOI silver medalist, ICPC WF, IGM
  3. Aryan Choudhary (aryanc403), Asia West Champion in WF 2021, GM
  4. Utkarsh Gupta (demoralizer), 2x ICPC WF, GM
  5. ⁠Himanshu Singh (hitman623), ICPC WF, GM
  6. ⁠Priyansh Agrawal (Priyansh31dec), ICPC WF
  7. Vivek Gupta (acraider), ICPC WF, Master, 7* on Codechef
  8. Gaurish Baliga (Queue), Master on CF
  9. Deepak Gour (Enigma27), ICPC WF

⁠ Date: December 4th to December 11th 2024

Location: NST | RU Campus, Sonipat (Near Delhi)

Registration Deadline: 18th Nov 2024

Registration Link: Fill this form for interest

Update : Join the Discord community

Update 2 : Had an awesome podcast with IICPC team on the the GoForGold Camp and how to improve the overall CP culture.

Update 3 :

Since ICPC prelims will be organized again and it will be difficult for the teams to arrange for travel in short duration thus we will be selecting teams on the basis of :

1. Your past performance in ICPC Regionals/AWC/WF

2. Average rating of your team (~1800+ for div2 and ~2100+ for div1 with some advantage for 2nd/3rd year and IOI candidates)

3. If you have solved >=4 problems in the recent prelims round.

Once you fill the interest form, we will wait till ICPC prelims result and you will get either a direct invite or a meet link with IICPC team after which we will select teams. (All of this will be done before 18th of Nov)

Prizes

Top 3 teams of both the divisions will get prizes

Partners and Volunteers

Thanks to Priyansh31dec and Queue for volunteering to take sessions and helping in the camp. You guys are such a good sport and will act as the examples for the current gen of aspirants to volunteer in future initiatives

Thanks s_jaskaran_s for helping in the brainstorming the ideation of the camp and working in building the amazing CP community

Thanks IICPC for amazing discussion and providing the CP perspective from the POV of current ICPC aspirants. Also thanks to volunteer in the team selection for the camp.

Thanks acraider for joining in this initiative and promoting the CP culture in India.

  • Educators

Thanks Dominater069 , demoralizer, hitman623, aryanc403, Queue, Arpa, Priyansh31dec for helping as educators and transfering your experience to the future gen.

  • Special Thanks

Thanks Ashishgup and kr_abhinav for giving some really good ideas from Alumni perspective. It was fun to be on a call and discuss the good old days with both of you.

To make this a mission, we would like to call upon all the enthusiasts and passionate people to join the camp. We will require a lot of help in preparing material and content. We would like it to be a community-driven initiative from the start. If you want to help, please fill out the form.

Full text and comments »

  • Vote: I like it
  • +167
  • Vote: I do not like it

By Enigma27, 5 years ago, In English

1208A — XORinacci

The sequence is $$$a$$$, $$$b$$$, $$$a\oplus b$$$, $$$a$$$, $$$b$$$, $$$a\oplus b$$$ $$$\cdots$$$

Since, the sequence has a period of $$$3$$$, $$$f[i] = f[i \mod 3]$$$.

Code

1208B — Uniqueness

After removing a sub-segment, a prefix and a suffix remain, possibly of length $$$0$$$. Let us fix the prefix which does not contain any duplicate elements and find the maximum suffix we can get without repeating the elements. We can use map/set to keep track of the elements.

Time complexity: $$$O(n^2 \cdot log(n))$$$

Code
Bonus

1208C — Magic Grid

Divide the grid into four quadrants. Assign distinct integers to the first quadrant from $$$0$$$ to $$$(\frac{N^2}{4} - 1)$$$. Copy this quadrant to the other three. This way XOR of each row and column becomes $$$0$$$.

Now, to make numbers distinct among the quadrants, multiply the numbers by $$$4$$$. Add $$$1$$$, $$$2$$$, and $$$3$$$ to the numbers in $$$1^{st}$$$, $$$2^{nd}$$$ and $$$3^{rd}$$$ quadrants respectively. The XOR of each row and column would still remain $$$0$$$ as $$$N/2$$$ is also even but the elements will become distinct while being in the range $$$[0, N^2-1].$$$

Another approach in this problem is to use a $$$ 4 \times 4$$$ grid given in the sample itself and replicate it in $$$N \times N$$$ grid by adding $$$16, 32, 48 \cdots $$$ to make the elements distinct.

Of course, there are multiple ways to solve the problem. These are just a few of them.

Code

1208D — Restore Permutation

Approach 1

Let us fill the array with numbers from $$$1$$$ to $$$N$$$ in increasing order.

$$$1$$$ will lie at the last index $$$i$$$ such that $$$s_{i} = 0$$$. Find and remove this index $$$i$$$ from the array and for all indices greater than $$$i$$$, reduce their $$$s_{i}$$$ values by $$$1$$$. Repeat this process for numbers $$$2, 3, ...N$$$. In the $$$i^{th}$$$ turn, reduce the elements by $$$i$$$.

To find the last index with value zero, we can use segment tree to get range minimum query with lazy propagation.

Time complexity: $$$O(N \cdot log(N))$$$

Code
Approach 2

For every i from $$$N$$$ to 1, let's say the value of the $$$s_{i}$$$ is x. So it means there are $$$k$$$ smallest unused numbers whose sum is $$$x$$$. We simply put the $$$k+1$$$st number in the output permutation at this $$$i$$$, and continue to move left. This can be implemented using BIT and binary lifting.

Thanks to real.emerald for expressing the solution in the above words.

Code

1208E — Let them slide

For every array $$$i$$$ from $$$1$$$ to $$$N$$$, let us maintain 2 pointers $$$L[i]$$$ and $$$R[i]$$$, representing the range of elements in $$$i_{th}$$$ array, that can be accessed by the current column index $$$j$$$.

Initially all $$$L[i]$$$ and $$$R[i]$$$ would be set equal to 0.

As we move from $$$j_{th}$$$ index to $$$(j+1)_{th}$$$ index, some $$$L[i]$$$ and $$$R[i]$$$ would change. Specifically, all those arrays which have $$$size \ge min(j,W-j-1)$$$ would have their $$$L[i]$$$ and $$$R[i]$$$ change.

Since overall movement of $$$L[i]$$$ and $$$R[i]$$$ would be equal to $$$2 \cdot$$$ size_of_array($$$i$$$). Overall change would be of order of $$$O(\sum a[i])$$$. For every array we need range max query in $$$(L[i], R[i])$$$.

We can use multisets/ segment trees/ deques to update the answers corresponding to an array if its $$$L[i], R[i]$$$ changes. This way we can get complexity $$$O(N)$$$ or $$$O(N \cdot log(N))$$$ depending upon implementation.

Code

1208F — Bits And Pieces

The idea is to first fix some $$$a[i]$$$ and try to get the bits which are off in $$$a[i]$$$ from any $$$2$$$ elements to the right of $$$i$$$. Since, we need to maximize the value, we will try to get higher bits first. What we need now is, for every number $$$x$$$ from $$$0$$$ to $$$2^{21}-1$$$, the $$$2$$$ right most positions such that the bits present in $$$x$$$ are also present in the elements on those positions. This can be done by iterating over submasks(slow) or SOS-DP(fast).

Once we process the positions for every $$$x$$$, let us fix some $$$a[i]$$$ and iterate over the bits which are off in $$$a[i]$$$ from the highest to the lowest. Lets say the current maximum we have got is $$$w$$$ and we are going to consider the $$$y^{th}$$$ bit. We can get this bit if the $$$2$$$ positions for $$$w|2^{y}$$$ are to the right of $$$i$$$ else we can not.

The final answer would be the maximum of $$$a[i]|w$$$ over all $$$i$$$ from $$$1$$$ to $$$N$$$.

Time complexity $$$O((M+N)\cdot logM)$$$ where $$$M$$$ is the max element in the array.

Code

1208G — Polygons

If we choose a polygon with side length $$$l$$$, it is profitable to choose polygons with side lengths as divisors of $$$l$$$ as well, because this will not increase the answer.

So our final set would be such that for every polygon with side length $$$l$$$, we would have polygons with side length as divisors of $$$l$$$ as well.

All polygons should have at least one common point in the final arrangement, say $$$P$$$ or else we can rotate them and get such $$$P$$$. For formal proof, please refer this comment by orz.

Let us represent points on the circle as the distance from point $$$P$$$. Like for $$$k$$$ sided polygon, $$$0$$$,$$$\frac{1}{k} ,\frac{2}{k} ,…\frac{k-1}{k}$$$.

Now the number of unique fractions over all the polygons would be our answer, which is equal to sum of $$$ \phi (l)$$$ over all side lengths $$$l$$$ of the polygons because for $$$l$$$ sided polygon there will be $$$\phi(l)$$$ extra points required by it as compared to its divisors.

One observation to get to the final solution is $$$\phi(l) \ge \phi(divisor(l))$$$. So, we can sort the side lengths by their $$$\phi$$$ values and take the smallest $$$k$$$ of them. This will minimize the number of points as well as satisfy the property of our set.

NOTE: We can not consider polygon of side length $$$2$$$. This can be handled easily.

Code
Tutorial is loading...
Code

Full text and comments »

  • Vote: I like it
  • +133
  • Vote: I do not like it

By Enigma27, history, 6 years ago, In English

I would like to invite you all to the International Coding Marathon 2019, under the banner of Technex'19, IIT (BHU) Varanasi.

Technex is the annual techno-management fest of Indian Institute of Technology (BHU), Varanasi organized from March 8 — 10, 2019.

International Coding Marathon is the flagship event of Byte The Bits, the set of programming events organized under Technex. ICM is brought to you by Mentor Graphics. It will take place on Friday, 8th March 2019, 21:00 IST. The contest will be held on Codechef.

The problemset has been prepared by hitman623, dhirajfx3, _shanky, drastogi21 and me (Enigma27). We would like to express our heartiest thanks to _hiccup and prakhar28 for their constant help in preparing the contest.

Prizes -

Overall 1st — INR 15,000

Overall 2nd — INR 10,000

India 1st — INR 9,000

India 2nd — INR 5,000

IIT(BHU) 1st — INR 6,000

IIT(BHU) 2nd — INR 4,000

IIT(BHU) Freshmen 1st — INR 1,000

Some of our previous contests :

ICM Technex 2017 and Codeforces Round #400 (Div. 1 + Div. 2, combined)

ICM Technex 2018 and Codeforces Round #463 (Div. 1 + Div. 2, combined)

Participants will have 2 hours 30 minutes to solve 7 problems. The scoring will be ICPC style.

Contest Link

Good luck everyone! Hope to see you on the leaderboard.

UPD — Contest begins in 1.5 hours

UPD1 — Contest begins in 15 minutes

UPD2 — Contest has ended. Congratulations to the winners. They will be contacted soon.

We deeply regret the inconvenience caused due to the problem ICM03. We will try to avoid such things in the future.

Editorials will be uploaded soon. Feel free to discuss the problems in the comment section.

UPD3 — The editorial is up.

Array Got Some Moves
Bob and his strict Mom
Snorlax hates working out
Yet Another Counting Problem
Pika-Pika
Good Sequence

Full text and comments »

  • Vote: I like it
  • +123
  • Vote: I do not like it

By Enigma27, history, 6 years ago, In English

Hi, Codeforces Community!

Codefest'18 — a diverse roster of high-quality programming competitions by Department of Computer Science and Engineering, IIT(BHU), Varanasi is excited to present Perplexed — the constrained programming event.

Perplexed is one of the most innovative events of CodeFest, whose target is not only gauge a contestant's coding abilities but also how one tackles different situations and constraints. The problemset will include all mind-boggling coding problems, ranging from code obfuscation to stricter memory limits, character limits, time limits, etc

The contest will take place at HackerRank. This contest will be an individual event with a duration of 3 hours, from Aug/31/2018 21:00 IST. With the creativity that the problems will naturally encourage and INR 50,000 at stake, there is absolutely no reason for a programmer to not give this one a shot!

The contest has been prepared by GT_18, code_kika, Rmatrix and me(Enigma27).

Prizes -

1st Prize-Rs.20000

2nd Prize-Rs.12000

3rd Prize-Rs.8000

1st in India-Rs.6000

1st in IIT(BHU)-Rs.3000

1st in 1/2 year in IIT(BHU)-Rs.1000

UPD : Contest has ended

Overall Winners

  1. tourist
  2. Golovanov399
  3. Marcin_smu

India First : hitman623

Full text and comments »

  • Vote: I like it
  • +86
  • Vote: I do not like it