เราได้รับตัวเลข n เราต้องหาตัวเลขที่มากกว่า n โดยมี set bit มากกว่า n หนึ่งตัวในการแทนค่าไบนารี
ตัวเลข 1 ในการแทนค่าไบนารีเรียกว่าบิตเซ็ต
มาดูตัวอย่างกัน
ป้อนข้อมูล
124
ผลผลิต
125
อัลกอริทึม
-
เริ่มต้นหมายเลข 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 + 1 == getSetBitsCount(i)) {
return i;
}
i += 1;
}
}
int main() {
int n = 124;
cout << getNextGreaterElementWithSameSetBits(n) << endl;
return 0;
} ผลลัพธ์
หากคุณเรียกใช้โค้ดด้านบน คุณจะได้ผลลัพธ์ดังต่อไปนี้
125