Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ตัวเลขที่สูงกว่าถัดไปด้วยจำนวนบิตชุดเดียวกันใน C++


เราได้รับตัวเลข n เราต้องหาตัวเลขที่มากกว่า n โดยมีจำนวนบิตเซ็ตเท่ากันกับ n ในการแทนค่าไบนารี

ตัวเลข 1 ในการแทนค่าไบนารีเรียกว่าบิตเซ็ต

มาดูตัวอย่างกัน

ป้อนข้อมูล

124

ผลผลิต

143

อัลกอริทึม

  • เริ่มต้นหมายเลข n.

  • เขียนฟังก์ชันรับจำนวนชุดบิต

  • เริ่มต้นตัวแปรวนซ้ำด้วย n + 1

  • เขียนวนไม่สิ้นสุด

    • ตรวจสอบจำนวนเซตบิตสำหรับตัวเลขที่เท่ากับจำนวนเซตบิตของ n

    • ส่งคืนหมายเลขเมื่อพบ

    • เพิ่มจำนวน

การนำไปใช้

ต่อไปนี้เป็นการนำอัลกอริธึมข้างต้นไปใช้ใน C++

#include <bits/stdc++.h>
using namespace std;
int getSetBitsCount(int n) {
   int count = 0;
   while (n) {
      if (n % 2 == 1) {
         count += 1;
      }
      n /= 2;
   }
   return count;
}
int getNextGreaterElementWithSameSetBits(int n) {
   int setBitsCount = getSetBitsCount(n);
   int i = n + 1;
   while (true) {
      if (setBitsCount == getSetBitsCount(i)) {
         return i;
      }
      i += 1;
   }
}
int main() {
   int n = 124;
   cout << getNextGreaterElementWithSameSetBits(n) << endl;
   return 0;
}

ผลลัพธ์

หากคุณเรียกใช้โค้ดด้านบน คุณจะได้ผลลัพธ์ดังต่อไปนี้

143