इस भाग में, हम देखेंगे कि कोई संख्या 8 की घात है या किसी आसान विधि का उपयोग नहीं कर रही है। यदि 4096 जैसी कोई संख्या है, तो प्रोग्राम सही होगा, क्योंकि यह 8 की शक्ति है।
चाल सरल है। हम log8(num) की गणना करेंगे। यदि यह एक पूर्णांक है, तो n 8 की शक्ति है। यहां हम दोहरे मान के निकटतम पूर्णांक को खोजने के लिए tranc(n) फ़ंक्शन का उपयोग करेंगे।
उदाहरण
#include <iostream>
#include <cmath>
using namespace std;
bool isPowerOfEight(int n) {
double val = log(n)/log(8); //get log n to the base 8
return (val - trunc(val) < 0.000001);
}
int main() {
int number = 4096;
if(isPowerOfEight(number)){
cout << number << " is power of 8";
} else {
cout << number << " is not power of 8";
}
} आउटपुट
4096 is power of 8