मुझे सी में किसी संख्या के लॉग बेस 2 की गणना करने की आवश्यकता है लेकिन मैं गणित पुस्तकालय का उपयोग नहीं कर सकता। उत्तर को निकटतम int तक सटीक होने की आवश्यकता नहीं है। मैंने इसके बारे में सोचा है और मुझे पता है कि मैं थोड़ी देर के लूप का उपयोग कर सकता हूं और < 2 तक संख्या को विभाजित रख सकता हूं, और पुनरावृत्तियों की गिनती रखता हूं, लेकिन क्या यह बिटवाई ऑपरेटरों का उपयोग कर संभव है?बिटवाई ऑपरेटरों का उपयोग कर कंप्यूटर लॉग बेस 2 कैसे करें?
उत्तर
यदि आप थोड़ा सा ऑपरेटर के रूप में shifting गिनते हैं, तो यह आसान है।
आप पहले से ही जानते हैं कि कैसे द्वारा 2.
x >> 1
लगातार प्रभाग द्वारा यह करने के लिए सी
में किसी भी अहस्ताक्षरित पूर्णांक के लिए x/2
के रूप में ही आप इस तेजी से बनाने के लिए की जरूरत है, आप एक कर सकते हैं "विभाजित करें और जीतें" -शिफ्ट, कहें, एक समय में 4 बिट्स जब तक आप 0 तक नहीं पहुंच जाते, फिर वापस जाएं और अंतिम 4 बिट्स देखें। इसका मतलब है कि प्रत्येक के 63 में से 16 बदलाव और 1 9 की तुलना में तुलना करता है। चाहे यह एक आधुनिक सीपीयू पर वास्तव में तेज़ है, मैं परीक्षण के बिना नहीं कह सकता था। और आप इसे पहले चरण में ले जा सकते हैं, पहले 16 के समूह, फिर 4, फिर 1. संभवतः यहां उपयोगी नहीं है, लेकिन यदि आपके पास कुछ 1024-बिट पूर्णांक हैं, तो यह विचार करने योग्य हो सकता है।
धन्यवाद, मुझे नहीं पता था कि यह कितना स्पष्ट था। मैं यह समझ गया। – SKLAK
@ स्क्लाक: अतिरिक्त मज़े के लिए, '/ 2' और' >> 1' कोड को -O2 के साथ संकलित करने का प्रयास करें और देखें कि यह अलग कैसे है। यदि कोई दूसरे की तुलना में काफी तेज है, तो आप दोनों के लिए सटीक कोड प्राप्त कर सकते हैं। – abarnert
वे केवल 'हस्ताक्षरित' के लिए समान होंगे। 'Int' के लिए, साइन बिट को पहले से जोड़ने के लिए एक अतिरिक्त ऑपरेशन है, जो सुनिश्चित करता है कि परिणाम नकारात्मक अनंतता के बजाय शून्य की ओर गोल करता है। –
पहले से ही abamert द्वारा उत्तर दिया लेकिन सिर्फ अधिक ठोस है कि यह कैसे आप इसे कोड होता है होने के लिए:
Log2(x) = result
while (x >>= 1) result++;
आप गिनी जाती हैं [स्थानांतरण] (http://en.wikipedia.org/wiki/Bitwise_operation#Bit_shifts) थोड़ा सा ऑपरेटर के रूप में? यदि ऐसा है, तो जवाब बहुत स्पष्ट है। यदि नहीं, तो यह मुश्किल है। – abarnert
0_o आप गणित पुस्तकालय का उपयोग क्यों नहीं कर सकते? –
@ जैकमेन: संभवतः यह या तो होमवर्क, या स्वयं शिक्षण समकक्ष है। लेकिन यह ठीक है; ऐसा लगता है कि उसने इसमें कुछ प्रयास किया है (वह हमेशा एक कामकाजी समाधान है), और यह देखने के लिए संकेतों की तलाश कर रहा है कि ऐसा करने का दूसरा तरीका है, न कि हमें उसके लिए अपना होमवर्क करने के लिए कहें। – abarnert