ਬਾਈਨਰੀ ਖੋਜ ਐਲਗੋਰਿਦਮ ਇੱਕ ਕ੍ਰਮਬੱਧ ਐਰੇ ਵਿੱਚ ਇੱਕ ਖਾਸ ਮੁੱਲ ਲੱਭਣ ਲਈ ਇੱਕ ਕੁਸ਼ਲ ਢੰਗ ਹੈ। ਇਹ ਪਹੁੰਚ ਐਰੇ ਨੂੰ ਛੋਟੇ ਭਾਗਾਂ ਵਿੱਚ ਵੰਡਦੀ ਹੈ ਅਤੇ ਲਗਾਤਾਰ ਖੋਜ ਰੇਂਜ ਦੀ ਮੱਧ ਸਥਿਤੀ 'ਤੇ ਮੁੱਲ ਦੀ ਟੀਚਾ ਮੁੱਲ ਨਾਲ ਤੁਲਨਾ ਕਰਦੀ ਹੈ। ਜੇਕਰ ਮੁੱਲ ਮੇਲ ਖਾਂਦੇ ਹਨ, ਤਾਂ ਲੋੜੀਦਾ ਮੁੱਲ ਪਾਇਆ ਜਾਂਦਾ ਹੈ; ਨਹੀਂ ਤਾਂ, ਐਲਗੋਰਿਦਮ ਖੋਜ ਰੇਂਜ ਨੂੰ ਸੰਕੁਚਿਤ ਕਰਨਾ ਜਾਰੀ ਰੱਖਦਾ ਹੈ ਅਤੇ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਉਦੋਂ ਤੱਕ ਦੁਹਰਾਉਂਦਾ ਹੈ ਜਦੋਂ ਤੱਕ ਮੁੱਲ ਨਹੀਂ ਮਿਲ ਜਾਂਦਾ ਜਾਂ ਕੋਈ ਹੋਰ ਤੱਤ ਜਾਂਚਣ ਲਈ ਨਹੀਂ ਬਚਦਾ ਹੈ।
ਕਦਮ:
- ਖੋਜ ਰੇਂਜ ਨੂੰ ਸ਼ੁਰੂ ਕਰੋ: ਐਰੇ ਦੀ ਪਹਿਲੀ ਸਥਿਤੀ ਤੋਂ
left
ਆਖਰੀ ਸਥਿਤੀ ਤੱਕ ਖੋਜ ਰੇਂਜ ਨੂੰ ਚੁਣ ਕੇ ਸ਼ੁਰੂ ਕਰੋ ।right
- ਮੱਧ ਬਿੰਦੂ ਲੱਭੋ: ਔਸਤ
left
ਅਤੇ ਸਹੀ ਸਥਿਤੀਆਂ ਦੁਆਰਾ ਮੱਧ ਬਿੰਦੂ ਦੀ ਗਣਨਾ ਕਰੋ; ਇਹ ਖੋਜ ਰੇਂਜ ਦਾ ਮੱਧ ਬਿੰਦੂ ਹੈ। - ਮੁੱਲਾਂ ਦੀ ਤੁਲਨਾ ਕਰੋ: ਮਿਡਲ ਪੁਆਇੰਟ 'ਤੇ ਮੁੱਲ ਦੀ ਟੀਚਾ ਮੁੱਲ ਨਾਲ ਤੁਲਨਾ ਕਰੋ।
- ਹੈਂਡਲ ਤੁਲਨਾ ਨਤੀਜੇ: ਜੇਕਰ ਮੱਧ ਬਿੰਦੂ 'ਤੇ ਮੁੱਲ ਟੀਚੇ ਦੇ ਮੁੱਲ ਨਾਲ ਮੇਲ ਖਾਂਦਾ ਹੈ, ਤਾਂ ਇਸ ਸਥਿਤੀ ਨੂੰ ਵਾਪਸ ਕਰੋ। ਜੇਕਰ ਮੱਧ ਬਿੰਦੂ 'ਤੇ ਮੁੱਲ ਟੀਚਾ ਮੁੱਲ ਤੋਂ ਘੱਟ ਹੈ, ਤਾਂ ਸੱਜੇ ਅੱਧ ਨੂੰ ਖੋਜਣ ਲਈ ਖੱਬੀ ਸਥਿਤੀ ਨੂੰ ਮੱਧ + 1 'ਤੇ ਅੱਪਡੇਟ ਕਰੋ। ਜੇਕਰ ਮੱਧ ਬਿੰਦੂ 'ਤੇ ਮੁੱਲ ਟੀਚਾ ਮੁੱਲ ਤੋਂ ਵੱਧ ਹੈ, ਤਾਂ ਖੱਬੇ ਅੱਧ ਨੂੰ ਖੋਜਣ ਲਈ ਮੱਧ- 1 'ਤੇ ਸਹੀ ਸਥਿਤੀ ਨੂੰ ਅੱਪਡੇਟ ਕਰੋ।
- ਦੁਹਰਾਓ: ਕਦਮ 2 ਤੋਂ 4 ਤੱਕ ਦੁਹਰਾਓ ਜਦੋਂ ਤੱਕ ਮੁੱਲ ਨਹੀਂ ਮਿਲਦਾ ਜਾਂ ਜਾਂਚ ਕਰਨ ਲਈ ਕੋਈ ਹੋਰ ਤੱਤ ਨਹੀਂ ਹਨ
left > right
।
ਫਾਇਦੇ ਅਤੇ ਨੁਕਸਾਨ
ਲਾਭ:
- ਕੁਸ਼ਲ ਪ੍ਰਦਰਸ਼ਨ: ਐਲਗੋਰਿਦਮ ਦੀ ਸਮਾਂ ਗੁੰਝਲਤਾ O(log n) ਹੈ, ਜਿਸ ਨਾਲ ਇਹ ਵੱਡੇ ਡੇਟਾਸੇਟਾਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਬਹੁਤ ਕੁਸ਼ਲ ਬਣਾਉਂਦਾ ਹੈ।
- ਵੱਡੇ ਡੇਟਾਸੈਟਾਂ ਲਈ ਪ੍ਰਭਾਵੀ: ਬਾਈਨਰੀ ਖੋਜ ਵੱਡੇ ਡੇਟਾਸੈਟਾਂ ਲਈ ਤੇਜ਼ੀ ਨਾਲ ਜਾਂਚ ਕਰਨ ਲਈ ਤੱਤਾਂ ਦੀ ਸੰਖਿਆ ਨੂੰ ਘਟਾਉਣ ਵਿੱਚ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਹੈ।
ਨੁਕਸਾਨ:
- ਸਿਰਫ਼ ਕ੍ਰਮਬੱਧ ਐਰੇ 'ਤੇ ਲਾਗੂ: ਐਲਗੋਰਿਦਮ ਸਿਰਫ਼ ਕ੍ਰਮਬੱਧ ਐਰੇ 'ਤੇ ਕੰਮ ਕਰਦਾ ਹੈ।
- ਪੜਾਵਾਂ ਦੀ ਵੇਰੀਏਬਲ ਸੰਖਿਆ: ਮੁੱਲ ਨੂੰ ਲੱਭਣ ਲਈ ਲੋੜੀਂਦੇ ਕਦਮਾਂ ਦੀ ਗਿਣਤੀ ਐਰੇ ਵਿੱਚ ਇਸਦੀ ਸਥਿਤੀ 'ਤੇ ਨਿਰਭਰ ਕਰਦੀ ਹੈ, ਅਤੇ ਇਹ ਸਿਰੇ ਦੇ ਨੇੜੇ ਮੁੱਲਾਂ ਲਈ ਕਈ ਕਦਮ ਚੁੱਕ ਸਕਦੀ ਹੈ।
ਉਦਾਹਰਨ: PHP ਵਿੱਚ ਕ੍ਰਮਬੱਧ ਐਰੇ ਵਿੱਚ ਮੁੱਲ 12 ਨੂੰ ਲੱਭਣ ਲਈ ਬਾਈਨਰੀ ਖੋਜ
ਉਦਾਹਰਨ ਦੀ ਵਿਆਖਿਆ
- ਅਸੀਂ ਸ਼ੁਰੂਆਤੀ ਖੋਜ ਰੇਂਜ ਨੂੰ ਪਹਿਲੀ ਸਥਿਤੀ ਤੋਂ ਐਰੇ ਦੀ
left = 0
ਆਖਰੀ ਸਥਿਤੀ ਤੱਕ ਸ਼ੁਰੂ ਕਰਦੇ ਹਾਂ।right = 6
- ਅਸੀਂ ਖੱਬੇ ਅਤੇ ਸੱਜੇ ਸਥਿਤੀਆਂ ਦੀ ਔਸਤ ਦੁਆਰਾ ਮੱਧ ਬਿੰਦੂ(ਮੱਧ) ਦੀ ਗਣਨਾ ਕਰਦੇ ਹਾਂ;
mid = 3
. ਮੱਧ 'ਤੇ ਮੁੱਲ 12 ਹੈ। - ਅਸੀਂ) 'ਤੇ ਮੁੱਲ ਦੀ
mid(12
ਟੀਚਾ ਮੁੱਲ(12) ਨਾਲ ਤੁਲਨਾ ਕਰਦੇ ਹਾਂ ਅਤੇ ਇੱਕ ਮੇਲ ਲੱਭਦੇ ਹਾਂ, ਇਸ ਲਈ ਅਸੀਂ ਸਥਿਤੀ 3 ਵਾਪਸ ਕਰਦੇ ਹਾਂ। - ਐਲਗੋਰਿਦਮ ਖਤਮ ਹੁੰਦਾ ਹੈ, ਅਤੇ ਅਸੀਂ ਨਤੀਜਾ "ਮੁੱਲ 12 ਸਥਿਤੀ 3 'ਤੇ ਪਾਇਆ।"