จากจำนวน n เราต้องหาจำนวนเต็มที่มีเซตบิตเป็นจำนวนคี่ในรูปแบบไบนารีของพวกมัน มาดูตัวอย่างกัน
ป้อนข้อมูล
n = 10
ผลผลิต
5
มีเลขจำนวนเต็ม 5 จำนวนตั้งแต่ 1 ถึง 10 โดยมีชุดบิตเป็นเลขคี่ในรูปแบบไบนารี
อัลกอริทึม
-
เริ่มต้นหมายเลข N.
- เขียนฟังก์ชันเพื่อนับจำนวนชุดบิตในรูปแบบไบนารี
-
เริ่มต้นการนับเป็น 0.
-
เขียนลูปที่วนซ้ำจาก 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 getOddSetBitsIntegerCount(int n) {
int count = 0;
for (int i = 1; i <= n; i++) {
if (getSetBitsCount(i) % 2 == 1) {
count += 1;
}
}
return count;
}
int main() {
int n = 10;
cout << getOddSetBitsIntegerCount(n) << endl;
return 0;
} ผลลัพธ์
หากคุณเรียกใช้โค้ดด้านบน คุณจะได้ผลลัพธ์ดังต่อไปนี้
5