ਲੁਹਨ ਅਲਗੋਰਿਦਮ ਨਾਲ ਨੰਬਰਾਂ ਦੀ ਪੁਸ਼ਟੀ ਅਤੇ ਤਿਆਰ ਕਰੋ

ਲੁਹਨ ਅਲਗੋਰਿਦਮ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਨੰਬਰਾਂ ਦੀ ਪੁਸ਼ਟੀ ਅਤੇ ਤਿਆਰ ਕਰੋ, ਜੋ ਆਮ ਤੌਰ 'ਤੇ ਕਰੈਡਿਟ ਕਾਰਡ ਨੰਬਰਾਂ, ਕੈਨੇਡੀਅਨ ਸੋਸ਼ਲ ਇਨਸ਼ੋਰੈਂਸ ਨੰਬਰਾਂ ਅਤੇ ਹੋਰ ਪਛਾਣ ਨੰਬਰਾਂ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ। ਜਾਂਚ ਕਰੋ ਕਿ ਕੋਈ ਨੰਬਰ ਲੁਹਨ ਚੈਕ 'ਤੇ ਪਾਸ ਹੁੰਦਾ ਹੈ ਜਾਂ ਲੁਹਨ ਅਲਗੋਰਿਦਮ ਨਾਲ ਅਨੁਕੂਲ ਵੈਧ ਨੰਬਰ ਬਣਾਓ।

ਲੁਹਨ ਅਲਗੋਰਿਦਮ ਕੈਲਕੁਲੇਟਰ

📚

ਦਸਤਾਵੇਜ਼ੀਕਰਣ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਕੈਲਕੁਲੇਟਰ

ਪਰੀਚਯ

ਲੁਨ ਅਲਗੋਰਿਦਮ, ਜਿਸਨੂੰ "ਮੋਡੁਲਸ 10" ਜਾਂ "ਮੋਡ 10" ਅਲਗੋਰਿਦਮ ਵੀ ਕਿਹਾ ਜਾਂਦਾ ਹੈ, ਇੱਕ ਸਧਾਰਨ ਚੈਕਸਮ ਫਾਰਮੂਲਾ ਹੈ ਜੋ ਕ੍ਰੈਡਿਟ ਕਾਰਡ ਨੰਬਰਾਂ, ਕੈਨੇਡੀਅਨ ਸੋਸ਼ਲ ਇਨਸ਼ੋਰੈਂਸ ਨੰਬਰਾਂ, IMEI ਨੰਬਰਾਂ ਅਤੇ ਸੰਯੁਕਤ ਰਾਜ ਵਿੱਚ ਨੈਸ਼ਨਲ ਪ੍ਰੋਵਾਈਡਰ ਆਈਡੈਂਟੀਫਾਇਰ ਨੰਬਰਾਂ ਵਰਗੇ ਵੱਖ-ਵੱਖ ਪਛਾਣ ਨੰਬਰਾਂ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ। ਇਹ ਕੈਲਕੁਲੇਟਰ ਤੁਹਾਨੂੰ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਨੰਬਰਾਂ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਅਤੇ ਲੁਨ ਚੈਕ ਪਾਸ ਕਰਨ ਵਾਲੇ ਮਾਨਯ ਨੰਬਰਾਂ ਨੂੰ ਤਿਆਰ ਕਰਨ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ।

ਲੁਨ ਅਲਗੋਰਿਦਮ ਕਿਵੇਂ ਕੰਮ ਕਰਦਾ ਹੈ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਇਸ ਤਰ੍ਹਾਂ ਕੰਮ ਕਰਦਾ ਹੈ:

  1. ਸੱਜੇ ਪਾਸੇ ਦੇ ਸਭ ਤੋਂ ਦਾਅਵਾਂ ਅੰਕ ਤੋਂ ਸ਼ੁਰੂ ਕਰਦੇ ਹੋਏ (ਚੈਕ ਅੰਕ ਨੂੰ ਛੱਡ ਕੇ) ਹਰ ਦੂਜੇ ਅੰਕ ਦੀ ਕੀਮਤ ਨੂੰ ਦੋ ਗੁਣਾ ਕਰੋ।
  2. ਜੇ ਇਸ ਦੋ ਗੁਣਾ ਕਰਨ ਦੀ ਕਾਰਵਾਈ ਦਾ ਨਤੀਜਾ 9 ਤੋਂ ਵੱਧ ਹੈ, ਤਾਂ ਨਤੀਜੇ ਵਿੱਚੋਂ 9 ਘਟਾਓ।
  3. ਨਤੀਜੇ ਦੇ ਅੰਕਾਂ ਦਾ ਜੋੜ ਕਰੋ।
  4. ਜੇ ਕੁੱਲ ਮੋਡਿਊਲੋ 10 0 ਦੇ ਬਰਾਬਰ ਹੈ (ਜੇ ਕੁੱਲ 0 'ਤੇ ਖਤਮ ਹੁੰਦਾ ਹੈ), ਤਾਂ ਨੰਬਰ ਲੁਨ ਫਾਰਮੂਲੇ ਦੇ ਅਨੁਸਾਰ ਮਾਨਯ ਹੈ; ਨਹੀਂ ਤਾਂ ਇਹ ਮਾਨਯ ਨਹੀਂ ਹੈ।

ਇੱਥੇ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦਾ ਵਿਜ਼ੂਅਲ ਪ੍ਰਦਰਸ਼ਨ ਹੈ:

1. ਹਰ ਦੂਜੇ ਅੰਕ ਨੂੰ ਦੋ ਗੁਣਾ ਕਰੋ 2. ਅੰਕਾਂ ਦਾ ਜੋੜ (9 ਲਈ ਦੋ ਗੁਣਾ > 9) 3. ਕੁੱਲ ਜੋੜ ਦੀ ਗਣਨਾ ਕਰੋ 4. ਚੈਕ ਕਰੋ ਕਿ ਜੋੜ % 10 == 0

ਫਾਰਮੂਲਾ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਨੂੰ ਗਣਿਤੀ ਤੌਰ 'ਤੇ ਇਸ ਤਰ੍ਹਾਂ ਪ੍ਰਗਟ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ:

ਮੰਨ ਲਓ did_i ii-ਵਾਂ ਅੰਕ ਹੈ, ਸੱਜੇ ਪਾਸੇ ਦੇ ਸਭ ਤੋਂ ਦਾਅਵਾਂ ਅੰਕ ਤੋਂ ਗਿਣਤੀ ਕਰਦੇ ਹੋਏ (ਚੈਕ ਅੰਕ ਨੂੰ ਛੱਡ ਕੇ) ਅਤੇ ਖੱਬੇ ਪਾਸੇ ਜਾ ਰਿਹਾ ਹੈ। ਤਾਂ ਚੈਕ ਅੰਕ d0d_0 ਇਸ ਤਰ੍ਹਾਂ ਚੁਣਿਆ ਜਾਂਦਾ ਹੈ ਕਿ:

(2d2nmod9+d2n1+2d2n2mod9+d2n3++2d2mod9+d1+d0)mod10=0(2d_{2n} \bmod 9 + d_{2n-1} + 2d_{2n-2} \bmod 9 + d_{2n-3} + \cdots + 2d_2 \bmod 9 + d_1 + d_0) \bmod 10 = 0

ਜਿੱਥੇ mod\bmod ਮੋਡੁਲੋ ਕਾਰਵਾਈ ਹੈ।

ਵਰਤੋਂ ਦੇ ਕੇਸ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੇ ਵੱਖ-ਵੱਖ ਖੇਤਰਾਂ ਵਿੱਚ ਕਈ ਐਪਲੀਕੇਸ਼ਨ ਹਨ:

  1. ਕ੍ਰੈਡਿਟ ਕਾਰਡ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ: ਜ਼ਿਆਦਾਤਰ ਕ੍ਰੈਡਿਟ ਕਾਰਡ ਨੰਬਰਾਂ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਕੀਤੀ ਜਾਂਦੀ ਹੈ।
  2. ਕੈਨੇਡੀਅਨ ਸੋਸ਼ਲ ਇਨਸ਼ੋਰੈਂਸ ਨੰਬਰ: ਲੁਨ ਅਲਗੋਰਿਦਮ ਇਨ੍ਹਾਂ ਪਛਾਣ ਨੰਬਰਾਂ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ।
  3. IMEI ਨੰਬਰ: ਮੋਬਾਈਲ ਫੋਨ IMEI ਨੰਬਰਾਂ ਵਿੱਚ ਇੱਕ ਚੈਕ ਅੰਕ ਹੁੰਦਾ ਹੈ ਜੋ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੁਆਰਾ ਪ੍ਰਮਾਣਿਤ ਹੁੰਦਾ ਹੈ।
  4. ਨੈਸ਼ਨਲ ਪ੍ਰੋਵਾਈਡਰ ਆਈਡੈਂਟੀਫਾਇਰ (NPI) ਨੰਬਰ: ਸੰਯੁਕਤ ਰਾਜ ਦੇ ਸਿਹਤ ਪ੍ਰਣਾਲੀ ਵਿੱਚ ਵਰਤੇ ਜਾਂਦੇ, ਇਹ ਨੰਬਰ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਪ੍ਰਮਾਣਿਤ ਕੀਤੇ ਜਾਂਦੇ ਹਨ।
  5. ISBNs: ਕੁਝ ISBN-10 ਨੰਬਰ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੇ ਇੱਕ ਵੈਰੀਐਂਟ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਪ੍ਰਮਾਣਿਤ ਹੁੰਦੇ ਹਨ।

ਵਿਕਲਪ

ਜਦੋਂ ਕਿ ਲੁਨ ਅਲਗੋਰਿਦਮ ਵਿਆਪਕ ਤੌਰ 'ਤੇ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ, ਪਰ ਵੱਖ-ਵੱਖ ਉਦੇਸ਼ਾਂ ਲਈ ਹੋਰ ਚੈਕਸਮ ਅਲਗੋਰਿਦਮ ਵੀ ਹਨ:

  1. ਡੈਮ ਅਲਗੋਰਿਦਮ: ਇੱਕ ਹੋਰ ਚੈਕ ਡਿਜ਼ਿਟ ਅਲਗੋਰਿਦਮ ਜੋ ਸਾਰੇ ਇਕਲ-ਅੰਕ ਦੀਆਂ ਗਲਤੀਆਂ ਅਤੇ ਸਾਰੇ ਪਾਸੇ ਦੇ ਟ੍ਰਾਂਸਪੋਜ਼ੀਸ਼ਨ ਗਲਤੀਆਂ ਦਾ ਪਤਾ ਲਗਾਉਂਦਾ ਹੈ।
  2. ਵਰਹੋਏਫ ਅਲਗੋਰਿਦਮ: ਇੱਕ ਹੋਰ ਜਟਿਲ ਚੈਕਸਮ ਅਲਗੋਰਿਦਮ ਜੋ ਸਾਰੇ ਇਕਲ-ਅੰਕ ਦੀਆਂ ਗਲਤੀਆਂ ਅਤੇ ਜ਼ਿਆਦਾਤਰ ਟ੍ਰਾਂਸਪੋਜ਼ੀਸ਼ਨ ਗਲਤੀਆਂ ਨੂੰ ਪਕੜਦਾ ਹੈ।
  3. ISBN-13 ਚੈਕ ਡਿਜ਼ਿਟ: ISBN-10 ਨਾਲੋਂ ਵੱਖਰਾ ਅਲਗੋਰਿਦਮ ਵਰਤਦਾ ਹੈ, ਜੋ ਲੁਨ ਅਲਗੋਰਿਦਮ ਦੇ ਆਧਾਰ 'ਤੇ ਹੈ।

ਇਤਿਹਾਸ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਨੂੰ ਹੈਂਸ ਪੀਟਰ ਲੁਨ ਦੁਆਰਾ ਬਣਾਇਆ ਗਿਆ ਸੀ, ਜੋ ਕਿ ਇੱਕ IBM ਕੰਪਿਊਟਰ ਵਿਗਿਆਨੀ ਸੀ, 1954 ਵਿੱਚ। ਲੁਨ ਜਾਣਕਾਰੀ ਵਿਗਿਆਨ ਦੇ ਖੇਤਰ ਵਿੱਚ ਇੱਕ ਪਾਇਨੀਅਰ ਸੀ ਅਤੇ ਕਈ ਨਵੀਨਤਾਵਾਂ ਦਾ ਕਰੇਡਿਟ ਹੈ, ਜਿਸ ਵਿੱਚ 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))  # ਸਹੀ
23print(luhn_validate(4532015112830367))  # ਗਲਤ
24print(generate_valid_number(16))  # ਇੱਕ ਮਾਨਯ 16-ਅੰਕ ਨੰਬਰ ਬਣਾਉਂਦਾ ਹੈ
25

ਕਿਨਾਰਿਆਂ ਦੇ ਕੇਸ ਅਤੇ ਵਿਸ਼ੇਸ਼ ਵਿਚਾਰ

ਲੁਨ ਅਲਗੋਰਿਦਮ ਨੂੰ ਲਾਗੂ ਕਰਨ ਵੇਲੇ, ਹੇਠਾਂ ਦਿੱਤੇ ਕੁਝ ਕਿਨਾਰਿਆਂ ਦੇ ਕੇਸਾਂ ਅਤੇ ਵਿਸ਼ੇਸ਼ ਵਿਚਾਰਾਂ ਨੂੰ ਧਿਆਨ ਵਿੱਚ ਰੱਖੋ:

  1. ਇਨਪੁਟ ਪ੍ਰਮਾਣਿਕਤਾ: ਇਹ ਯਕੀਨੀ ਬਣਾਓ ਕਿ ਇਨਪੁਟ ਇੱਕ ਮਾਨਯ ਨੰਬਰ ਸਤਰ ਹੈ। ਗੈਰ-ਅੰਕ ਅੱਖਰਾਂ ਨੂੰ ਢੰਗ ਨਾਲ ਸੰਭਾਲਿਆ ਜਾਣਾ ਚਾਹੀਦਾ ਹੈ (ਜਾਂ ਤਾਂ ਹਟਾਇਆ ਜਾਂ ਜਾਂ ਗਲਤ ਇਨਪੁਟ ਵਜੋਂ ਵਿਵਹਾਰ ਕੀਤਾ ਜਾਣਾ ਚਾਹੀਦਾ ਹੈ)।

  2. ਲੀਡਿੰਗ ਜ਼ਿਰੋ: ਇਹ ਅਲਗੋਰਿਦਮ ਲੀਡਿੰਗ ਜ਼ਿਰੋ ਵਾਲੇ ਨੰਬਰਾਂ ਨਾਲ ਸਹੀ ਤਰ੍ਹਾਂ ਕੰਮ ਕਰਨਾ ਚਾਹੀਦਾ ਹੈ।

  3. ਵੱਡੇ ਨੰਬਰ: ਕੁਝ ਪ੍ਰੋਗ੍ਰਾਮਿੰਗ ਭਾਸ਼ਾਵਾਂ ਵਿੱਚ ਆਮ ਇੰਟੇਜਰ ਕਿਸਮਾਂ ਦੀ ਸਮਰੱਥਾ ਤੋਂ ਵੱਧ ਲੰਬੇ ਨੰਬਰਾਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਤਿਆਰ ਰਹੋ।

  4. ਖਾਲੀ ਇਨਪੁਟ: ਤੁਹਾਡੇ ਲਾਗੂ ਕਰਨ ਨੂੰ ਇਹ ਪਰਿਭਾਸ਼ਿਤ ਕਰੋ ਕਿ ਖਾਲੀ ਸਤਰਾਂ ਜਾਂ ਨੱਲ ਇਨਪੁਟ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਣਾ ਚਾਹੀਦਾ ਹੈ।

  5. ਗੈਰ-ਮਿਆਰੀ ਅੱਖਰ ਸੈੱਟ: ਕੁਝ ਐਪਲੀਕੇਸ਼ਨਾਂ ਵਿੱਚ, ਤੁਸੀਂ ਅਜਿਹੇ ਨੰਬਰਾਂ ਦਾ ਸਾਹਮਣਾ ਕਰ ਸਕਦੇ ਹੋ ਜੋ ਮਿਆਰੀ 0-9 ਰੇਂਜ ਤੋਂ ਬਾਹਰ ਦੇ ਅੱਖਰਾਂ ਨਾਲ ਪ੍ਰਸਤੁਤ ਕੀਤੇ ਗਏ ਹਨ। ਇਹਨਾਂ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਣਾ ਚਾਹੀਦਾ ਹੈ, ਇਹ ਪਰਿਭਾਸ਼ਿਤ ਕਰੋ।

  6. ਪ੍ਰਦਰਸ਼ਨ ਦੇ ਵਿਚਾਰ: ਐਪਲੀਕੇਸ਼ਨਾਂ ਲਈ ਜੋ ਬਹੁਤ ਸਾਰੇ ਇਨਪੁਟਾਂ ਦੀ ਪ੍ਰਮਾਣਿਕਤਾ ਨੂੰ ਤੇਜ਼ੀ ਨਾਲ ਕਰਨ ਦੀ ਜ਼ਰੂਰਤ ਹੈ, ਅਲਗੋਰਿਦਮ ਦੀ ਕਾਰਜਾਨੁਸ਼ਾਸਨ ਨੂੰ ਸੁਧਾਰਨ ਦੇ ਬਾਰੇ ਵਿਚਾਰ ਕਰੋ।

ਸੰਖਿਆਤਮਕ ਉਦਾਹਰਣ

  1. ਮਾਨਯ ਕ੍ਰੈਡਿਟ ਕਾਰਡ ਨੰਬਰ:

    • ਨੰਬਰ: 4532015112830366
    • ਲੁਨ ਚੈਕ: ਮਾਨਯ
  2. ਗਲਤ ਕ੍ਰੈਡਿਟ ਕਾਰਡ ਨੰਬਰ:

    • ਨੰਬਰ: 4532015112830367
    • ਲੁਨ ਚੈਕ: ਗਲਤ
  3. ਮਾਨਯ ਕੈਨੇਡੀਅਨ ਸੋਸ਼ਲ ਇਨਸ਼ੋਰੈਂਸ ਨੰਬਰ:

    • ਨੰਬਰ: 046 454 286
    • ਲੁਨ ਚੈਕ: ਮਾਨਯ
  4. ਗਲਤ 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

ਹਵਾਲੇ

  1. ਲੁਨ, ਐਚ. ਪੀ. (1960). "ਨੰਬਰਾਂ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਕੰਪਿਊਟਰ". ਯੂਐਸ ਪੇਟੈਂਟ 2,950,048.
  2. ਗੈਲਿਅਨ, ਜੋਸਫ। "ਪਛਾਣ ਨੰਬਰਾਂ ਦੀ ਗਣਿਤ". ਕਾਲਜ ਮੈਥਮੈਟਿਕਸ ਜਰਨਲ, vol. 22, no. 3, 1991, pp. 194–202. JSTOR, www.jstor.org/stable/2686878.
  3. "ISO/IEC 7812-1:2017". ਅੰਤਰਰਾਸ਼ਟਰੀ ਸੰਗਠਨ ਲਈ ਮਿਆਰਬੰਦੀ। 2 ਅਗਸਤ, 2024 ਨੂੰ ਪ੍ਰਾਪਤ ਕੀਤਾ।
  4. ਕਨੂਥ, ਡੋਨਾਲਡ। "ਕੰਪਿਊਟਰ ਪ੍ਰੋਗ੍ਰਾਮਿੰਗ ਦੀ ਕਲਾ, ਖੰਡ 2: ਸਿਮੀਨਮਰੀਕਲ ਅਲਗੋਰਿਦਮ". ਐਡਿਸਨ-ਵੈਸਲੀ, 1997.