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