ਬਾਈਨਰੀ ਖੋਜ ਐਲਗੋਰਿਦਮ ਇੱਕ ਕ੍ਰਮਬੱਧ ਸੂਚੀ ਵਿੱਚ ਇੱਕ ਖਾਸ ਤੱਤ ਦੀ ਖੋਜ ਕਰਨ ਦਾ ਇੱਕ ਵਧੇਰੇ ਕੁਸ਼ਲ ਤਰੀਕਾ ਹੈ। ਲੀਨੀਅਰ ਖੋਜ ਦੇ ਉਲਟ, ਜੋ ਕ੍ਰਮਵਾਰ ਤੱਤਾਂ ਦੀ ਜਾਂਚ ਕਰਦਾ ਹੈ, ਬਾਈਨਰੀ ਖੋਜ ਸੂਚੀ ਨੂੰ ਅੱਧਿਆਂ ਵਿੱਚ ਵੰਡਦੀ ਹੈ ਅਤੇ ਮਿਡਲ ਐਲੀਮੈਂਟ ਨਾਲ ਟਾਰਗੇਟ ਐਲੀਮੈਂਟ ਦੀ ਤੁਲਨਾ ਕਰਦੀ ਹੈ। ਇਹ ਪ੍ਰਕਿਰਿਆ ਉਦੋਂ ਤੱਕ ਦੁਹਰਾਈ ਜਾਂਦੀ ਹੈ ਜਦੋਂ ਤੱਕ ਟੀਚਾ ਤੱਤ ਨਹੀਂ ਮਿਲਦਾ ਜਾਂ ਖੋਜ ਰੇਂਜ ਖਾਲੀ ਨਹੀਂ ਹੋ ਜਾਂਦੀ।
ਕਿਦਾ ਚਲਦਾ
- ਪੂਰੀ ਕ੍ਰਮਬੱਧ ਸੂਚੀ ਨਾਲ ਸ਼ੁਰੂ ਕਰੋ।
- ਮੌਜੂਦਾ ਖੋਜ ਰੇਂਜ ਦਾ ਮੱਧ ਤੱਤ ਲੱਭੋ।
- ਮਿਡਲ ਐਲੀਮੈਂਟ ਦੀ ਟੀਚਾ ਮੁੱਲ ਨਾਲ ਤੁਲਨਾ ਕਰੋ।
- ਜੇ ਮੱਧ ਤੱਤ ਟੀਚੇ ਦੇ ਮੁੱਲ ਦੇ ਬਰਾਬਰ ਹੈ, ਤਾਂ ਖੋਜ ਸਫਲ ਹੈ.
- ਜੇਕਰ ਵਿਚਕਾਰਲਾ ਤੱਤ ਟੀਚੇ ਤੋਂ ਵੱਡਾ ਹੈ, ਤਾਂ ਰੇਂਜ ਦੇ ਖੱਬੇ ਅੱਧ ਵਿੱਚ ਖੋਜ ਕਰੋ।
- ਜੇਕਰ ਮੱਧ ਤੱਤ ਟੀਚੇ ਤੋਂ ਛੋਟਾ ਹੈ, ਤਾਂ ਸੀਮਾ ਦੇ ਸੱਜੇ ਅੱਧ ਵਿੱਚ ਖੋਜ ਕਰੋ।
- ਕਦਮ 2-6 ਨੂੰ ਉਦੋਂ ਤੱਕ ਦੁਹਰਾਓ ਜਦੋਂ ਤੱਕ ਟੀਚਾ ਤੱਤ ਨਹੀਂ ਮਿਲਦਾ ਜਾਂ ਖੋਜ ਰੇਂਜ ਖਾਲੀ ਨਹੀਂ ਹੋ ਜਾਂਦੀ।
ਉਦਾਹਰਨ
ਆਓ ਪੂਰਨ ਅੰਕਾਂ ਦੀ ਕ੍ਰਮਬੱਧ ਸੂਚੀ 'ਤੇ ਵਿਚਾਰ ਕਰੀਏ ਅਤੇ ਬਾਈਨਰੀ ਖੋਜ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਨੰਬਰ 34 ਨੂੰ ਲੱਭਣਾ ਚਾਹੁੰਦੇ ਹਾਂ।
ਕ੍ਰਮਬੱਧ ਸੂਚੀ: {12, 23, 34, 45, 56, 67, 89, 90}
- ਪੂਰੀ ਸੂਚੀ ਨਾਲ ਸ਼ੁਰੂ ਕਰੋ.
- ਮੱਧ ਤੱਤ: 56(ਸਥਿਤੀ 4). 34 ਨਾਲ ਤੁਲਨਾ ਕਰੋ।
- 56 34 ਤੋਂ ਵੱਡਾ ਹੈ। ਖੱਬੇ ਅੱਧ ਵਿੱਚ ਖੋਜੋ।
- ਨਵਾਂ ਮੱਧ ਤੱਤ: 23(ਸਥਿਤੀ 1) 34 ਨਾਲ ਤੁਲਨਾ ਕਰੋ।
- 23 34 ਤੋਂ ਛੋਟਾ ਹੈ। ਸੱਜੇ ਅੱਧ ਵਿੱਚ ਖੋਜੋ।
- ਨਵਾਂ ਮੱਧ ਤੱਤ: 45(ਸਥਿਤੀ 3) 34 ਨਾਲ ਤੁਲਨਾ ਕਰੋ।
- 45 34 ਤੋਂ ਵੱਡਾ ਹੈ। ਖੱਬੇ ਅੱਧ ਵਿੱਚ ਖੋਜੋ।
- ਨਵਾਂ ਮੱਧ ਤੱਤ: 34(ਸਥਿਤੀ 2) ਟੀਚਾ ਮਿਲਿਆ।
C++ ਵਿੱਚ ਉਦਾਹਰਨ ਕੋਡ
ਦਿੱਤੀ ਗਈ ਉਦਾਹਰਨ ਵਿੱਚ, binarySearch
ਫੰਕਸ਼ਨ ਦੀ ਵਰਤੋਂ ਪੂਰਨ ਅੰਕਾਂ ਦੀ ਲੜੀਬੱਧ ਸੂਚੀ ਵਿੱਚ ਨੰਬਰ 34 ਨੂੰ ਲੱਭਣ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ। ਨਤੀਜਾ ਸੂਚੀ ਵਿੱਚ 34 ਦੀ ਸਥਿਤੀ ਹੋਵੇਗੀ(ਪੋਜ਼ੀਸ਼ਨ 0 ਤੋਂ ਸ਼ੁਰੂ ਹੁੰਦੀ ਹੈ) ਜਾਂ -1 ਜੇਕਰ ਨੰਬਰ ਨਹੀਂ ਮਿਲਦਾ ਹੈ।