1. बिटवाइज डावीकडे शिफ्ट
Java मध्ये 3 bitwise shift ऑपरेटर देखील आहेत : जर तुम्हाला खरोखर गरज असेल, तर तुम्ही अगदी सोप्या पद्धतीने अनेक स्थानांचे सर्व बिट्स डावीकडे किंवा उजवीकडे हलवू शकता.
नंबरचे बिट डावीकडे शिफ्ट करण्यासाठी, तुम्हाला bitwise डावा शिफ्ट ऑपरेटर आवश्यक आहे . हे असे लिहिले आहे:
a << b
ती संख्या कोठे a
आहे ज्याचे बिट शिफ्ट केले जात आहेत आणि b
ही संख्या आहे जी संख्या किती वेळा a
डावीकडे हलवायची हे दर्शवते. या ऑपरेशन दरम्यान, उजवीकडे जोडलेले लो-ऑर्डर बिट्स शून्य आहेत.
उदाहरणे:
उदाहरण | परिणाम |
---|---|
|
|
|
|
|
|
|
|
एक अंक डावीकडे हलवण्याचा परिणाम 2 ने गुणाकार करण्यासारखाच होतो.
संख्या १६ ने गुणाकार करायची आहे? 16 हे 2 4 सारखे आहे . तर तुम्ही 4 अंक डावीकडे शिफ्ट करा
2. बिटवाइज उजवीकडे हलवा
बिट देखील उजवीकडे हलवता येतात. हे करण्यासाठी, बिटवाइज राईट शिफ्ट ऑपरेटर वापरा . हे असे लिहिले आहे:
a >> b
ज्या क्रमांकाचे बिट शिफ्ट केले जात आहेत ती संख्या कोठे a
आहे आणि b
त्या संख्येचे बिट a
उजवीकडे किती वेळा हलवायचे आहे.
उदाहरणे:
उदाहरण | परिणाम |
---|---|
|
|
|
|
|
|
|
|
एक अंक उजवीकडे हलवण्याचा परिणाम 2 ने भागाकार करण्यासारखाच होतो.
या ऑपरेशन दरम्यान, डावीकडे जोडलेले उच्च-ऑर्डर बिट्स शून्य आहेत, परंतु नेहमीच नाही !
स्वाक्षरी केलेल्या संख्येच्या सर्वात डावीकडील बिटला चिन्ह बिट म्हणतात : जर संख्या धनात्मक असेल, तर ती आहे 0
; परंतु जर संख्या ऋणात्मक असेल, तर हा बिट आहे 1
.
संख्येचे बिट उजवीकडे हलवताना, चिन्ह बिटचे मूल्य देखील सरकते आणि संख्येचे चिन्ह गमावले जाते. त्यानुसार, ऋण संख्यांसाठी (जेथे सर्वात डावी बिट आहे 1
), या बिटला विशेष उपचार मिळतात. एखाद्या संख्येचे बिट उजवीकडे हलवताना, 0
डावीकडील बिट असल्यास डावीकडे a जोडला जातो 0
आणि 1
डावीकडील बिट असल्यास डावीकडे a जोडला जातो 1
.
परंतु वरील उदाहरणात, तो परिणाम दिसत नाही. का? कारण पूर्णांक अक्षरे int
s आहेत आणि प्रत्यक्षात याचा अर्थ आहे . म्हणजेच, सर्वात डावीकडील बिट शून्य आहे.0b11111111
0b00000000000000000000000011111111
बरेच प्रोग्रामर या उजव्या-शिफ्ट वर्तनामुळे निराश झाले आहेत आणि संख्या नेहमी शून्याने पॅड करणे पसंत करतात. म्हणून Java ने दुसरा उजवा शिफ्ट ऑपरेटर जोडला .
हे असे लिहिले आहे:
a >>> b
ज्या क्रमांकाचे बिट शिफ्ट केले जात आहेत ती संख्या कोठे a
आहे आणि b
त्या संख्येचे बिट a
उजवीकडे किती वेळा हलवायचे आहे. नंबरच्या चिन्ह बिटच्या मूळ मूल्याकडे दुर्लक्ष करून हा ऑपरेटर नेहमी डावीकडे शून्य जोडतो a
.
3. ध्वजांसह कार्य करणे
प्रोग्रामरनी बिटवाइज आणि शिफ्ट ऑपरेशन्सच्या आधारे अभ्यासाचे जवळजवळ संपूर्ण नवीन क्षेत्र तयार केले: ध्वजांसह कार्य करणे.
जेव्हा कॉम्प्युटरची मेमरी फारच कमी होती, तेव्हा एका नंबरमध्ये बरीच माहिती क्रॅम करणे हे अत्यंत लोकप्रिय होते. संख्या बिट्सची अॅरे मानली गेली: एक इंट 32 बिट आहे आणि एक लांब 64 बिट आहे.
तुम्ही अशा संख्येत बरीच माहिती लिहू शकता, विशेषत: जर तुम्हाला तार्किक ( true
किंवा false
) मूल्ये साठवायची असतील. एकल 64 घटकांच्या long
अॅरेप्रमाणे आहे . या बिट्सला फ्लॅगboolean
म्हटले गेले आणि पुढील ऑपरेशन्स वापरून हाताळले गेले:
-
ध्वज सेट करा(विशिष्ट बिट समान करा
1
) -
ध्वज रीसेट करा(विशिष्ट बिट समान करा
0
) -
ध्वज तपासा(विशिष्ट बिटचे मूल्य तपासा)
आणि बिटवाइज ऑपरेटर्ससह ते कसे केले जाते ते येथे आहे.
ध्वज सेट करणे
विशिष्ट बिट वर सेट करण्यासाठी 1
, तुम्हाला तुम्हाला ज्या क्रमांकाचा बिट सेट करायचा आहे आणि एक खास तयार केलेला आकडा, जेथे फक्त तो बिट आहे, त्यामध्ये bitwise OR ऑपरेशन करणे आवश्यक आहे 1
.
उदाहरणार्थ, समजा तुमच्याकडे नंबर आहे 0b00001010
आणि तुम्हाला 5 वा बिट वर सेट करणे आवश्यक आहे 1
. या प्रकरणात, आपण हे करणे आवश्यक आहे:
0b00001010 | 0b00010000 = 0b00011010
जर 5 वा बिट आधीच एक वर सेट केला असता, तर काहीही बदलले नसते.
सर्वसाधारणपणे, ध्वज सेट करण्याचे ऑपरेशन खालीलप्रमाणे लिहिले जाऊ शकते
a | (1 << b)
a
नंबर कुठे आहे ज्याचा बिट वर सेट केला जाईल 1
. आणि b
सेट करावयाच्या बिटची स्थिती आहे. डावी शिफ्ट ऑपरेटर वापरणे येथे अतिशय सोयीचे आहे, कारण आम्ही कोणत्या बिटसह काम करत आहोत हे तुम्ही लगेच सांगू शकता.
ध्वज रीसेट करत आहे
इतर बिट्समध्ये अडथळा न आणता विशिष्ट बिट रीसेट करण्यासाठी (म्हणजे ते सेट करा ), तुम्हाला ज्या नंबरचा बिट तुम्हाला रीसेट करायचा आहे (म्हणजे सेट करा) आणि विशेष तयार केलेल्या संख्येच्या दरम्यान ऑपरेशन 0
करणे आवश्यक आहे , जेथे सर्व बिट्स वगळता सर्व बिट्स समान आहेत आपण रीसेट करू इच्छित बिटसाठी.&
0
1
उदाहरणार्थ, समजा तुमच्याकडे नंबर आहे 0b00001010
आणि तुम्हाला 4 था बिट वर सेट करणे आवश्यक आहे 0
. या प्रकरणात, आपण हे करणे आवश्यक आहे:
0b00001010 & 0b11110111 = 0b00000010
जर 4था बिट आधीच शून्यावर सेट केला असता, तर काहीही बदलले नसते.
सर्वसाधारणपणे, ध्वज रीसेट करण्याचे ऑपरेशन खालीलप्रमाणे लिहिले जाऊ शकते
a & ~(1 << b)
तो नंबर कुठे a
आहे ज्याचा बिट वर रीसेट केला जाईल 0
. आणि b
बिटची स्थिती साफ करायची आहे.
1
एक संख्या मिळवण्यासाठी जिथे आपल्याला शून्य करायचे आहे त्याशिवाय सर्व बिट्स आहेत , आपण प्रथम 1 b पोझिशन्स डावीकडे हलवतो आणि नंतर NOT
परिणाम उलट करण्यासाठी bitwise ऑपरेटर वापरतो.
ध्वज तपासत आहे
विशिष्ट ध्वज सेट करणे किंवा रीसेट करण्याव्यतिरिक्त, काहीवेळा आपल्याला दिलेला ध्वज सेट केला आहे की नाही हे तपासणे आवश्यक आहे, म्हणजे विशिष्ट बिट बरोबर आहे की नाही 1
. हे bitwise सह करणे अगदी सोपे आहे &
.
उदाहरणार्थ, समजा तुम्हाला 4 था बिट 1
नंबरमध्ये सेट केला आहे की नाही हे तपासण्याची आवश्यकता आहे 0b00001010
. मग आपल्याला हे करण्याची आवश्यकता आहे:
if ( (0b00001010 & 0b00001000) == 0b00001000 )
सर्वसाधारणपणे, ध्वज तपासण्याचे ऑपरेशन खालीलप्रमाणे लिहिले जाऊ शकते
(a & (1 << b)) == (1 << b)
a
नंबर कोठे आहे ज्याचा बिट तपासला जात आहे. आणि b
तपासण्यासाठी बिटची स्थिती आहे.
4. एनक्रिप्शन
बिटवाइज XOR
ऑपरेशन सहसा प्रोग्रामरद्वारे साध्या एन्क्रिप्शनसाठी वापरले जाते. सर्वसाधारणपणे, असे कूटबद्धीकरण असे दिसते:
result = number ^ password;
number
आम्हाला जो डेटा एन्क्रिप्ट करायचा आहे तो कोठे आहे, password
डेटासाठी "पासवर्ड" म्हणून वापरला जाणारा एक विशेष क्रमांक आहे आणि result
तो एनक्रिप्ट केलेला नंबर आहे.
number == (number ^ password) ^ password;
येथे महत्त्वाची गोष्ट अशी आहे की जेव्हा XOR
ऑपरेटर दोनदा नंबरवर लागू केला जातो तेव्हा तो "पासवर्ड" विचारात न घेता मूळ क्रमांक तयार करतो.
number
मधून पुनर्प्राप्त करण्यासाठी encrypted result
, आपल्याला फक्त ऑपरेशन पुन्हा करणे आवश्यक आहे:
original number = result ^ password;
उदाहरण:
class Solution
{
public static int[] encrypt(int[] data, int password)
{
int[] result = new int[data.length];
for (int i = 0; i < data.length; i++)
result[i] = data[i] ^ password;
return result;
}
public static void main(String[] args)
{
int[] data = {1, 3, 5, 7, 9, 11};
int password = 199;
// Encrypt the array of data
int[] encrypted = encrypt(data, password);
System.out.println(Arrays.toString(encrypted));
// Decrypt the array of data
int[] decrypted = encrypt(encrypted, password);
System.out.println(Arrays.toString(decrypted));
}
}
GO TO FULL VERSION