¦WΘ1š-1šVтFY`2ô0Kθ4ÖUD2Qi\28X+ë<7%É31α}‹iY¬>0ëY1¾ǝDÅsD12‹i>1ë\1Dǝ¤>2}}ǝVY})DJIJk18+£35.£¬.•4ιõ÷‡o‹ƶ¸•2ôs`UÐ3‹12*+>13*5÷s3‹Xα©т%D4÷®т÷©4÷®·()DćsćsO7%._s€нT‰J«7ô»
ফর্ম্যাট ইনপুট [day, month, year]
। 0
একক-অঙ্কের দিনগুলির জন্য শীর্ষস্থানীয় এসগুলির সাথে আউটপুট এবং ছোট হাতের mo
মাধ্যমে su
(+1 বাইট যোগ করা যায় যদি টাইটেলিকেস বাধ্যতামূলক হয়)।
এটি অনলাইনে চেষ্টা করুন বা সমস্ত পরীক্ষার কেস যাচাই করুন ।
পবিত্র ছিঃ .. এটি আমার পক্ষে সবচেয়ে দীর্ঘতম 05 এফ 1 ই উত্তরের রেকর্ড হতে পারে এবং তারপরে আমি কিছু জটিল জটিল অসি-আর্ট চ্যালেঞ্জগুলি আমি অন্তর্ভুক্ত করেছি ...>।> সম্পাদনা: হুম ঠিক আছে, প্রায় ..; পি
গুরুত্বপূর্ণ দ্রষ্টব্য: 05AB1E তারিখের বিষয়গুলি বা গণনার জন্য কোনও বিল্টিন নেই। এটির তারিখ সম্পর্কিত একমাত্র বিল্টিন হ'ল আজকের বছর / মাস / দিন / ঘন্টা / মিনিট / সেকেন্ড / মাইক্রোসেকেন্ড।
সুতরাং সেই কারণে, আপনি যে কোডগুলি দেখতে পান তার প্রায় সবগুলি হ'ল আগের এবং পরের দিনগুলি গণনা করার জন্য ম্যানুয়াল গণনা (বহু বছরের পরিক্রমণ এবং লিপ বছরগুলি মাথায় রেখে) এবং জেলের মিলন ব্যবহার করে সপ্তাহের দিন গণনা করা ।
কোডটির বিশাল অংশগুলি আমার এই পূর্বের 05AB1E উত্তর থেকে অনুলিপি করা হয়েছে , যা নীচের ব্যাখ্যার জন্যও প্রাসঙ্গিক হবে।
ব্যাখ্যা:
আমরা আগের মাসের প্রথম দিনটিতে গিয়ে শুরু করি:
¦ # Remove the first item (the days) from the (implicit) input
W # Get the minimum (without popping the list itself)
# (since the year is guaranteed to be above 1599, this is the month)
Θ # Check if its exactly 1 (1 if 1, 0 if in the range [2,31])
1š # Prepend a 1 as list (so we now have either [1,1] or [1,0]
- # Subtract this from the month and year
1š # And prepend a 1 for the day
V # Pop and store this first day of the previous month in variable `Y`
তারপরে আমি সেই তারিখটি শুরুর তারিখ হিসাবে ব্যবহার করি এবং পরবর্তী 100 দিন গণনা করি:
тF # Loop 100 times:
Y`2ô0Kθ4ÖUD2Qi\28X+ë<7%É31α}‹iY¬>0ëY1¾ǝDÅsD12‹i>1ë\1Dǝ¤>2}}ǝV
# Calculate the next day in line
# (see the linked challenge above for a detailed explanation of this)
Y # And leave it on the stack
}) # After the loop: wrap the entire stack into a list, which contains our 100 days
তারপরে, মধ্যম হিসাবে ইনপুট-তারিখটি সহ, আমি কেবল 17 টি আগে এবং 17 তালিকা থেকে ইনপুট-তারিখ ছাড়ি:
DJ # Duplicate the 100 dates, and join the day/month/year together to strings
IJ # Push the input, also joined together
k # Get the 0-based index of the input in this list
# (the joins are necessary, because indexing doesn't work for 2D lists)
18+ # Add 18 to this index (18 instead of 17, because the index is 0-based)
£ # Only leave the first index+18 items from the 100 dates
35.£ # Then only leave the last 35 items
এখন আমাদের 35 দিন কেটে গেছে। পরবর্তী পদক্ষেপটি সপ্তাহের দিন গণনা করা এবং আউটপুট-টেবিলের শিরোনাম তৈরি করা হয়:
¬ # Get the first date of the list (without popping the list itself)
.•4ιõ÷‡o‹ƶ¸• # Push compressed string "sasumotuwethfr"
2ô # Split it into chunks of size 2
s # Swap to get the first date again
`UÐ3‹12*+>13*5÷s3‹Xα©т%D4÷®т÷©4÷®·()DćsćsO7%
# Calculate the day of the week (sa=0; su=1; ...; fr=6)
# (see the linked challenge above for a detailed explanation of this)
._ # Rotate the list of strings that many times
আমার এই 05AB1E টিপটি দেখুন (বিভাগটি কীভাবে স্ট্রিংগুলি সংকুচিত করবেন? ) কেন .•4ιõ÷‡o‹ƶ¸•
তা বোঝার জন্য "sasumotuwethfr"
।
তারপরে আমরা আমাদের আগের তৈরি তারিখের তালিকার উপর ভিত্তি করে টেবিলটি পূরণ করার দিনগুলি তৈরি করি। যা আমরা শিরোনামের সাথে একত্রীকরণ করব। যার পরে আমরা চূড়ান্ত ফলাফল মুদ্রণ করতে পারি:
s # Swap to get the list of dates again
€н # Only leave the first item of each date (the days)
T‰ # Take the divmod 10 of each
J # Join those divmod results together
# (we now have leading 0s for single-digit days)
« # Merge this list together with the header list
7ô # Split it into chunks of size 7
» # Join each inner list by spaces, and then each string by newlines
# (and output the result implicitly)