কম্পিউটার

C++ এ এনম ডিজিট


ধরুন আমাদের একটি অসীম পূর্ণসংখ্যার ক্রম আছে, আমাদের এই ক্রমটির nম সংখ্যাটি খুঁজে বের করতে হবে। সুতরাং যদি ইনপুট 11 হয়, তাহলে আউটপুট হবে 0 যেমন আমরা সংখ্যা রাখি যেমন 123456789101112, তাই 11 তম সংখ্যা 0।

এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -

  • len :=0 এবং cnt :=9 এবং শুরু :=1

  • যখন n> len * cnt

    • n :=n – (len * cnt)

    • cnt :=cnt * 10, start :=start * 10

    • 1 দ্বারা লেন বাড়ান

  • start :=start +(n - 1) / len

  • s :=স্ট্রিং হিসাবে শুরু করুন

  • রিটার্ন s[(n – 1) mod len]

উদাহরণ (C++)

আসুন আরও ভালোভাবে বোঝার জন্য নিচের বাস্তবায়ন দেখি −

#include <bits/stdc++.h>
using namespace std;
typedef long long int lli;
class Solution {
public:
   int findNthDigit(int n) {
      lli len = 1;
      lli cnt = 9;
      lli start = 1;
      while(n > len * cnt){
         n -= len * cnt;
         cnt *= 10;
         start *= 10;
         len++;
      }
      start += (n - 1) / len;
      string s = to_string(start);
      return s[(n - 1) % len] - '0';
   }
};
main(){
   Solution ob;
   cout << (ob.findNthDigit(11));
}

ইনপুট

11

আউটপুট

0

  1. C++-এ এক অঙ্কের সংখ্যা

  2. C++ এ a বা b দ্বারা বিভাজ্য Nth শব্দ খুঁজে বের করার প্রোগ্রাম

  3. C++ STL-এ iswdigit() ফাংশন

  4. nম সংখ্যাটি সন্ধান করুন যেখানে k সংখ্যাটি রয়েছে বা C++ এ k দ্বারা বিভাজ্য