लुहन अल्गोरिदम वापरून संख्या वैधता आणि निर्माण करा
लुहन अल्गोरिदम वापरून संख्या वैधता आणि निर्माण करा, जो सामान्यतः क्रेडिट कार्ड नंबर, कॅनेडियन सोशल इन्श्युरन्स नंबर आणि इतर ओळख क्रमांकांसाठी वापरला जातो. संख्या लुहन तपासणी पास करते का हे तपासा किंवा अल्गोरिदमच्या नियमांचे पालन करणारे वैध नंबर तयार करा.
लुहन अल्गोरिदम कॅल्क्युलेटर
साहित्यिकरण
लुहन अल्गोरिदम कॅल्क्युलेटर
परिचय
लुहन अल्गोरिदम, ज्याला "मॉड्युलस 10" किंवा "मॉड 10" अल्गोरिदम म्हणूनही ओळखले जाते, हा एक साधा चेकसम सूत्र आहे जो विविध ओळख क्रमांकांचे प्रमाणित करण्यासाठी वापरला जातो, जसे की क्रेडिट कार्ड क्रमांक, कॅनेडियन सोशल इन्शुरन्स क्रमांक, IMEI क्रमांक, आणि अमेरिकेत राष्ट्रीय प्रदाता ओळख क्रमांक. हा कॅल्क्युलेटर तुम्हाला लुहन अल्गोरिदमचा वापर करून क्रमांकांची वैधता तपासण्याची आणि लुहन चेक पास करणारे वैध क्रमांक तयार करण्याची परवानगी देतो.
लुहन अल्गोरिदम कसा कार्य करतो
लुहन अल्गोरिदम खालीलप्रमाणे कार्य करतो:
- उजव्या बाजूच्या सर्वात उजव्या अंकापासून (चेक अंक वगळून) सुरुवात करून, प्रत्येक दुसऱ्या अंकाचे मूल्य दुप्पट करा.
- जर या दुप्पट ऑपरेशनचा परिणाम 9 पेक्षा जास्त असेल, तर परिणामातून 9 वजा करा.
- परिणामी अनुक्रमातील सर्व अंकांची बेरीज करा.
- जर एकूण % 10 0 ला सम असले, तर संख्या लुहन सूत्रानुसार वैध आहे; अन्यथा, ती वैध नाही.
लुहन अल्गोरिदमचे दृश्य प्रतिनिधित्व येथे आहे:
सूत्र
लुहन अल्गोरिदम गणितीयदृष्ट्या खालीलप्रमाणे व्यक्त केला जाऊ शकतो:
जिथे हे मॉड्युलो ऑपरेशन आहे.
उपयोग केसेस
लुहन अल्गोरिदमचे विविध क्षेत्रांमध्ये अनेक अनुप्रयोग आहेत:
- क्रेडिट कार्ड वैधता: बहुतेक क्रेडिट कार्ड क्रमांक लुहन अल्गोरिदमचा वापर करून प्रमाणित केले जातात.
- कॅनेडियन सोशल इन्शुरन्स क्रमांक: या ओळख क्रमांकांची वैधता तपासण्यासाठी लुहन अल्गोरिदमचा वापर केला जातो.
- IMEI क्रमांक: मोबाइल फोन IMEI क्रमांकात लुहन अल्गोरिदमने प्रमाणित केलेला चेक अंक समाविष्ट आहे.
- राष्ट्रीय प्रदाता ओळख (NPI) क्रमांक: अमेरिकेच्या आरोग्य प्रणालीमध्ये वापरले जाणारे, या क्रमांकांची वैधता लुहन अल्गोरिदमने तपासली जाते.
- ISBNs: काही ISBN-10 क्रमांक लुहन अल्गोरिदमच्या एक भिन्न रूपाचा वापर करून प्रमाणित केले जातात.
पर्याय
जरी लुहन अल्गोरिदम व्यापकपणे वापरला जातो, तरीही विविध उद्देशांसाठी इतर चेकसम अल्गोरिदम आहेत:
- डॅम अल्गोरिदम: एक अन्य चेक अंक अल्गोरिदम जो सर्व एकल अंक त्रुटी आणि सर्व शेजारील ट्रान्सपोजिशन त्रुटी शोधतो.
- वेरहॉफ अल्गोरिदम: एक अधिक जटिल चेकसम अल्गोरिदम जो सर्व एकल अंक त्रुटी आणि बहुतेक ट्रान्सपोजिशन त्रुटी पकडतो.
- ISBN-13 चेक अंक: ISBN-10 पेक्षा भिन्न अल्गोरिदम वापरतो, जो लुहन अल्गोरिदमवर आधारित आहे.
इतिहास
लुहन अल्गोरिदम 1954 मध्ये IBM च्या संगणक शास्त्रज्ञ हंस पीटर लुहनने तयार केला. लुहन माहिती विज्ञानाच्या क्षेत्रात एक पायनियर होता आणि KWIC (की वर्ड इन कॉन्टेक्स्ट) अनुक्रमण प्रणालीसह अनेक नवकल्पनांसाठी श्रेय दिले जाते.
या अल्गोरिदमची रचना अनपेक्षित त्रुटींपासून संरक्षण करण्यासाठी करण्यात आली होती, दुष्ट हल्ल्यांपासून नाही. हे लक्षात घेणे महत्त्वाचे आहे की लुहन अल्गोरिदम अनेक सामान्य त्रुटी शोधू शकतो, परंतु हे डेटा सुरक्षेसाठी सुरक्षित रूप नाही आणि यावर अवलंबून राहू नये.
त्याच्या वयाच्या बाबतीत, लुहन अल्गोरिदम अद्याप त्याच्या साधेपणामुळे आणि सामान्य हस्तांतरण त्रुटी पकडण्यात प्रभावीतेमुळे व्यापकपणे वापरला जातो.
कार्यान्वयन उदाहरणे
येथे लुहन अल्गोरिदम विविध प्रोग्रामिंग भाषांमध्ये कार्यान्वित करण्याचे काही कोड उदाहरणे आहेत:
1import random
2
3def luhn_validate(number):
4 digits = [int(d) for d in str(number)]
5 checksum = 0
6 for i in range(len(digits) - 1, -1, -1):
7 d = digits[i]
8 if (len(digits) - i) % 2 == 0:
9 d = d * 2
10 if d > 9:
11 d -= 9
12 checksum += d
13 return checksum % 10 == 0
14
15def generate_valid_number(length):
16 digits = [random.randint(0, 9) for _ in range(length - 1)]
17 checksum = sum(digits[::2]) + sum(sum(divmod(d * 2, 10)) for d in digits[-2::-2])
18 check_digit = (10 - (checksum % 10)) % 10
19 return int(''.join(map(str, digits + [check_digit])))
20
21## उदाहरण वापर:
22print(luhn_validate(4532015112830366)) # True
23print(luhn_validate(4532015112830367)) # False
24print(generate_valid_number(16)) # एक वैध 16-अंकांचा क्रमांक तयार करतो
25
1function luhnValidate(number) {
2 const digits = number.toString().split('').map(Number);
3 let checksum = 0;
4 for (let i = digits.length - 1; i >= 0; i--) {
5 let d = digits[i];
6 if ((digits.length - i) % 2 === 0) {
7 d *= 2;
8 if (d > 9) d -= 9;
9 }
10 checksum += d;
11 }
12 return checksum % 10 === 0;
13}
14
15function generateValidNumber(length) {
16 const digits = Array.from({length: length - 1}, () => Math.floor(Math.random() * 10));
17 const checksum = digits.reduce((sum, digit, index) => {
18 if ((length - 1 - index) % 2 === 0) {
19 digit *= 2;
20 if (digit > 9) digit -= 9;
21 }
22 return sum + digit;
23 }, 0);
24 const checkDigit = (10 - (checksum % 10)) % 10;
25 return parseInt(digits.join('') + checkDigit);
26}
27
28// उदाहरण वापर:
29console.log(luhnValidate(4532015112830366)); // true
30console.log(luhnValidate(4532015112830367)); // false
31console.log(generateValidNumber(16)); // एक वैध 16-अंकांचा क्रमांक तयार करतो
32
1import java.util.Random;
2
3public class LuhnValidator {
4 public static boolean luhnValidate(long number) {
5 String digits = String.valueOf(number);
6 int checksum = 0;
7 boolean isEven = true;
8 for (int i = digits.length() - 1; i >= 0; i--) {
9 int digit = Character.getNumericValue(digits.charAt(i));
10 if (isEven) {
11 digit *= 2;
12 if (digit > 9) digit -= 9;
13 }
14 checksum += digit;
15 isEven = !isEven;
16 }
17 return checksum % 10 == 0;
18 }
19
20 public static long generateValidNumber(int length) {
21 Random random = new Random();
22 long[] digits = new long[length - 1];
23 for (int i = 0; i < length - 1; i++) {
24 digits[i] = random.nextInt(10);
25 }
26 long checksum = 0;
27 for (int i = digits.length - 1; i >= 0; i--) {
28 long digit = digits[i];
29 if ((length - 1 - i) % 2 == 0) {
30 digit *= 2;
31 if (digit > 9) digit -= 9;
32 }
33 checksum += digit;
34 }
35 long checkDigit = (10 - (checksum % 10)) % 10;
36 long result = 0;
37 for (long digit : digits) {
38 result = result * 10 + digit;
39 }
40 return result * 10 + checkDigit;
41 }
42
43 public static void main(String[] args) {
44 System.out.println(luhnValidate(4532015112830366L)); // true
45 System.out.println(luhnValidate(4532015112830367L)); // false
46 System.out.println(generateValidNumber(16)); // एक वैध 16-अंकांचा क्रमांक तयार करतो
47 }
48}
49
काठाच्या बाबी आणि विशेष विचार
लुहन अल्गोरिदम कार्यान्वित करताना, खालील काठाच्या बाबी आणि विशेष विचारांचा विचार करा:
-
इनपुट वैधता: सुनिश्चित करा की इनपुट एक वैध संख्या स्ट्रिंग आहे. नॉन-डिजिट वर्ण योग्यरित्या हाताळले पाहिजेत (किंवा काढले जावे किंवा अमान्य इनपुट म्हणून विचारले जावे).
-
लीडिंग झिरो: अल्गोरिदमने लीडिंग झिरो असलेल्या क्रमांकांसह योग्यरित्या कार्य करावे.
-
मोठे क्रमांक: काही प्रोग्रामिंग भाषांमधील मानक पूर्णांक प्रकारांच्या क्षमतेपेक्षा जास्त मोठ्या क्रमांकांचे हाताळण्यासाठी तयार रहा.
-
रिक्त इनपुट: तुमच्या कार्यान्वयनाने रिक्त स्ट्रिंग किंवा नल इनपुट कसे हाताळावे हे परिभाषित करा.
-
नॉन-स्टँडर्ड कॅरेक्टर सेट: काही अनुप्रयोगांमध्ये, तुम्हाला मानक 0-9 श्रेणीच्या बाहेर वर्णांद्वारे दर्शविलेले क्रमांक आढळू शकतात. हे कसे हाताळले जावे हे परिभाषित करा.
-
कार्यक्षमता विचार: ज्या अनुप्रयोगांना जलद गतीने मोठ्या संख्येच्या इनपुट्सची वैधता तपासण्याची आवश्यकता आहे, त्यांच्यासाठी अल्गोरिदम कार्यान्वयन ऑप्टिमाइझ करण्याचा विचार करा.
संख्यात्मक उदाहरणे
-
वैध क्रेडिट कार्ड क्रमांक:
- क्रमांक: 4532015112830366
- लुहन चेक: वैध
-
अमान्य क्रेडिट कार्ड क्रमांक:
- क्रमांक: 4532015112830367
- लुहन चेक: अमान्य
-
वैध कॅनेडियन सोशल इन्शुरन्स क्रमांक:
- क्रमांक: 046 454 286
- लुहन चेक: वैध
-
अमान्य IMEI क्रमांक:
- क्रमांक: 490154203237518
- लुहन चेक: अमान्य
चाचणी प्रकरणे
लुहन अल्गोरिदमच्या कार्यान्वयनाची पडताळणी करण्यासाठी, तुम्ही खालील चाचणी प्रकरणांचा वापर करू शकता:
1def test_luhn_algorithm():
2 assert luhn_validate(4532015112830366) == True
3 assert luhn_validate(4532015112830367) == False
4 assert luhn_validate(79927398713) == True
5 assert luhn_validate(79927398714) == False
6
7 # तयार केलेल्या क्रमांकांची चाचणी
8 for _ in range(10):
9 assert luhn_validate(generate_valid_number(16)) == True
10
11 print("सर्व चाचण्या यशस्वी झाल्या!")
12
13test_luhn_algorithm()
14
संदर्भ
- लुहन, एच. पी. (1960). "संख्यांची पडताळणी करणारा संगणक". यूएस पेटंट 2,950,048.
- गालियन, जोसेफ. "ओळख क्रमांकांचे गणित." कॉलेज गणित जर्नल, खंड 22, संख्यांक 3, 1991, पृष्ठ 194–202. JSTOR, www.jstor.org/stable/2686878.
- "ISO/IEC 7812-1:2017". आंतरराष्ट्रीय मानक संघटना. 2 ऑगस्ट 2024 रोजी प्राप्त.
- क्नुथ, डोनाल्ड. "संगणक प्रोग्रामिंगची कला, खंड 2: सेमीन्यूमेरिकल अल्गोरिदम". ऍडिसन-वेस्ली, 1997.
प्रतिसाद
या टूलविषयी अभिप्राय देण्याची प्रारंभिक अभिप्राय देण्यासाठी अभिप्राय टोस्ट वर क्लिक करा.