একটি প্রায় ভর বিহীন বিড়ালকে স্পেসে ফেলে দেওয়া হবে (উদ্বেগ করবেন না, একটি স্পেস স্যুট এবং সমস্ত কিছু দিয়ে) (x, y, z)
গতিবেগের সাথে (vx, vy, vz)
। বিন্দুতে একটি স্থির, অসীম ঘন গ্রহ রয়েছে (০ এর আয়তন সহ) (0, 0, 0)
এবং এটি r
ত্বরণের সাথে দূরত্বে বস্তুগুলিকে আকর্ষণ করে 1/r^2
। নিউটোনীয় মাধ্যাকর্ষণ অনুসারে, বস্তুটি সময়ের পরে কোথায় যায় t
?
এই ক্ষেত্রে প্রায় ভরবিহীন অর্থ হল আপনি এর মান আউটপুট করছেন lim (mass --> 0) <position of cat>
। ভর গ্রহের মাধ্যাকর্ষণ দ্বারা প্রভাবিত হয়, কিন্তু গ্রহটি বিড়ালের মাধ্যাকর্ষণ দ্বারা প্রভাবিত হয় না। অন্য কথায়, কেন্দ্রীয় সংস্থা স্থির হয়।
কোড গল্ফের সাথে এটি কিছুটা মিল : স্পেসশিপের ভাগ্য কী? [ভাসমান পয়েন্ট সংস্করণ] , তবে এটি আলাদা কারণ এটি যথার্থতা পরিমাপ করছে।
আপনি সিমুলেশন ভিত্তিক একটি সমাধান কার্যকর করতে পারেন, যা অবশ্যই 3 সেকেন্ডেরও কম সময়ে চলতে পারে, বা আপনি এমন কোনও প্রোগ্রাম বাস্তবায়ন করতে পারেন যা একটি সঠিক মান দেয় (এটি অবশ্যই 3 সেকেন্ডেরও কম সময়ে চালাতে হবে)। নীচে স্কোরিং বিবরণ দেখুন। আপনি যদি কোনও সিমুলেশন বাস্তবায়ন করেন তবে এটি সঠিক হতে হবে না তবে আপনার স্কোরটি ত্রুটির কারণে কম হবে।
ইনপুট : x y z vx vy vz t
অগত্যা যথাক্রমে X, Y, Z স্থানাঙ্ক, বেগ X, Y, ও টু Z নির্দেশ ও সময় প্রতিনিধিত্বমূলক পূর্ণসংখ্যার। এটি গ্যারান্টিযুক্ত যে বিড়ালের গতি সেই উচ্চতায় পালানোর গতির চেয়ে কঠোরভাবে কম। ইনপুট কোনও ফাংশনে প্যারামিটার সহ যে কোনও জায়গা থেকে নেওয়া যেতে পারে। প্রোগ্রামটি অবশ্যই আমার ল্যাপটপে তিন সেকেন্ডেরও কম সময়ে চলতে হবে t < 2^30
যার অর্থ, যদি আপনি কোনও সিমুলেশন চালাচ্ছেন তবে আপনাকে অবশ্যই আপনার টাইমস্টেপটি সেই অনুযায়ী সামঞ্জস্য করতে হবে। আপনি যদি প্রতিটি পরীক্ষার ক্ষেত্রে 3 সেকেন্ডের সীমাটি হিট করার পরিকল্পনা করে থাকেন তবে নিশ্চিত হন যে এমন একটি টিউনিয়েবল প্যারামিটার রয়েছে যা এটি আরও সঠিক / গতি লাভের জন্য কম নির্ভুল করে তুলতে পারে, যাতে আমি এটি আমার কম্পিউটারে তিন সেকেন্ডের মধ্যে চালাতে পারি।
আউটপুট : x y z
, সময় পর অবস্থান t
।
যেহেতু দ্বি-দেহের সমস্যাটি নিখুঁতভাবে সমাধান করা যায়, তাত্ত্বিকভাবে একটি নিখুঁত, সঠিক উত্তর পাওয়া সম্ভব।
স্কোরিং : যে কোনও পরীক্ষার ক্ষেত্রে ত্রুটিটিকে আপনার আউটপুট এবং "সত্য" আউটপুটের মধ্যে দূরত্ব হিসাবে সংজ্ঞায়িত করা হয়। আসল আউটপুটটিকে টেস্ট কেস স্নিপেট তৈরি করে বলে সংজ্ঞায়িত করা হয়। ত্রুটিটি যদি এর চেয়ে কম হয় 10^(-8)
তবে ত্রুটিটি শূন্যের নীচে হয়। আপনার স্কোরটি 100 (বা আরও) র্যান্ডম পরীক্ষার ক্ষেত্রে গড় ত্রুটি। আপনি যদি সঠিকভাবে সঠিক উত্তর লিখেন তবে আপনার 0 নম্বর পাওয়া উচিত; সর্বনিম্ন স্কোর জয়, এবং সংযোগ কোড দৈর্ঘ্য দ্বারা বিভক্ত হবে।
পরীক্ষার কেস :
1 0 0 0 -1 0 1000000000 --> 0.83789 -0.54584 0
এই ক্ষেত্রে, কক্ষপথ 2 * পিআই পিরিয়ডের সাথে পুরোপুরি বিজ্ঞপ্তিযুক্ত, সুতরাং 159154943 বার চক্কর দেওয়ার পরে, বিড়ালটি প্রায় শেষ হয় (0.83789, -0.54584)। এটি কোনও পরীক্ষার ক্ষেত্রে নয় যা আপনার কোডে পরীক্ষা করা হবে; আপনি যদি সঠিকভাবে সঠিক উত্তর জমা দেন তবে আপনি এটি এটি পরীক্ষা করতে চাইতে পারেন।
নীচে স্নিপেট এলোমেলো অতিরিক্ত পরীক্ষার কেস উত্পন্ন করে এবং সাবমিশনের বিচার করতে ব্যবহৃত হবে; এটির সাথে যদি কোনও বাগ থাকে তবে আমাকে জানান:
t
ইউনিট সময়ে দেওয়া হয়, যা কিছু হোক না কেন এবং বেগ একই ইউনিট ব্যবহার করবে। এটি সেকেন্ডে বা ঘন্টার মধ্যেই হোক, উত্তরটি একই হবে।
nearly massless cat
আচ্ছা, বিড়ালের সঠিক ভর কী হবে? আমাদের কি 0
এই বিড়ালের ভরটির জন্য মূল্য হিসাবে ব্যবহার করা উচিত ?
t
সেকেন্ডে দেওয়া হয়? যদি তা হয়, তবে গতিটি প্রতি সেকেন্ডে ইউনিট দেওয়া হত, বা আরও ছোট কিছু?