⊗ppSpOtAU 82 of 83 menu

PHP-তে অপ্রয়োজনীয় অ্যারে অপ্টিমাইজেশন

ধরুন একজন প্রোগ্রামারের কাছে কাজ হল ১ থেকে ১০০০০০০০ পর্যন্ত পূর্ণসংখ্যার যোগফল বের করা।

আমাদের প্রোগ্রামার এই সমস্যার একটি মার্জিত সমাধান লিখেছেন, এভাবে:

<?php echo array_sum(range(1, 100000000)); ?>

সুন্দর সমাধান, তাই না? এক লাইনে এবং সবকিছু। কিন্তু এটি কাজ করে না! এই কোডটি চালানোর চেষ্টা করুন এবং এটি স্ক্রিনে একটি ত্রুটি দেখাবে যে আপনি খুব বেশি র্যাম মেমরি অনুরোধ করেছেন।

হুম, ১০০০০০০০ মনে হয় তেমন বেশি নয়? নাকি বেশি? আসুন গণনা করি। ফাংশন range ১০০০০০০০ সংখ্যা সহ একটি অ্যারে তৈরি করে। ধরুন PHP একটি সংখ্যার জন্য ২ বাইট বরাদ্দ করে - তাহলে আমাদের অ্যারে সংরক্ষণের জন্য প্রয়োজন হবে ২০০০০০০০০ বাইট, যা প্রায় ২০০ মেগাবাইট র্যাম মেমরি।

কিন্তু বাস্তবে র্যাম মেমরির প্রয়োজন হবে এর চেয়ে অনেক বেশি কারণ PHP-এ অ্যারে সংরক্ষণ করার সময় খুব বড় ওভারহেড থাকে। উদাহরণস্বরূপ, আমার এখানে ত্রুটির বার্তায় বলা হয়েছে, যে আমি ৪২৯৪৯৬৭৩০৪ বাইট বরাদ্দ করার চেষ্টা করছি - যা প্রায় ৪ গিগাবাইট!

এখন বোঝা যাচ্ছে, কেন ত্রুটি ঘটছে - আমরা অনুমোদিত মেমরি সীমা ছাড়িয়ে গেছি।

আমাদের স্ক্রিপ্টটি অন্য উপায়ে পুনরায় লিখা কঠিন নয়, যা ব্যবহারিকভাবে র্যাম মেমরি ব্যবহার করবে না:

<?php $sum = 0; for ($i = 1; $i <= 100000000; $i++) { $sum += $i; } echo $sum; ?>

অথবা আরও ভাল, আমরা গাণিতিক সমাধান ব্যবহার করি:

<?php $n = 1000000; $sum = $n * ($n + 1) / 2; echo $sum; ?>

একজন প্রোগ্রামারের কাছে কাজ ছিল একটি প্রদত্ত সংখ্যার ফ্যাক্টোরিয়াল বের করা। তিনি এটি নিম্নলিখিতভাবে সমাধান করেছেন:

<?php $n = 100; echo array_product(range(1, $n)); ?>

ব্যাখ্যা করুন, এই কোডটির什么问题। কোডটিকে আরও অনুকূলভাবে পুনরায় লিখুন।

একজন প্রোগ্রামারের কাছে কাজ ছিল ১ থেকে ১০০০০০০ পর্যন্ত সমস্ত পূর্ণসংখ্যা লিখতে কতগুলি অঙ্ক ব্যবহার করা যায় তা বের করা। তিনি এটি নিম্নলিখিতভাবে সমাধান করেছেন:

<?php echo strlen(implode('', range(1, 1000000))); ?>

ব্যাখ্যা করুন, এই কোডটির什么问题। কোডটিকে আরও অনুকূলভাবে পুনরায় লিখুন।

একজন প্রোগ্রামারের কাছে কাজ ছিল একটি প্রদত্ত সীমার মধ্যে ৭ দ্বারা নিঃশেষে বিভাজ্য সংখ্যার সংখ্যা বের করা। তিনি এটি নিম্নলিখিতভাবে সমাধান করেছেন:

<?php $arr = []; for ($i = 0; $i <= 1000; $i++) { if ($i % 7 == 0) { $arr[] = $i; } } echo count($arr); ?>

ব্যাখ্যা করুন, এই কোডটির什么问题। কোডটিকে আরও অনুকূলভাবে পুনরায় লিখুন।

একজন প্রোগ্রামারের কাছে কাজ ছিল একটি সংখ্যার ভাজকের যোগফল বের করা। তিনি এটি নিম্নলিখিতভাবে সমাধান করেছেন:

<?php $num = 320; $divs = []; for ($i = 0; $i <= $num; $i++) { if ($num % $i == 0) { $divs[] = $i; } } echo array_sum($divs); ?>

ব্যাখ্যা করুন, এই কোডটির什么问题। কোডটিকে আরও অনুকূলভাবে পুনরায় লিখুন।

বাংলা
AfrikaansAzərbaycanБългарскиБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন