Heuristic శోధన అనేది హ్యూరిస్టిక్స్ లేదా బొటనవేలు యొక్క నియమాల ఆధారంగా సమాచార నిర్ణయాలు తీసుకోవడం ద్వారా సంక్లిష్ట సమస్య ప్రదేశాలలో పరిష్కారాలను కనుగొనడానికి ఉపయోగించే శక్తివంతమైన అల్గారిథమిక్ విధానం. పెద్ద శోధన స్థలం కారణంగా సమగ్ర శోధన అసాధ్యమైనప్పుడు ఇది ప్రత్యేకంగా ఉపయోగపడుతుంది.
అది ఎలా పని చేస్తుంది
- Heuristic మూల్యాంకనం: అల్గోరిథం ఒక ఫంక్షన్ని ఉపయోగించి సమస్య స్థలంలో ప్రతి స్థితిని అంచనా వేస్తుంది heuristic. ఈ ఫంక్షన్ లక్ష్య స్థితికి దాని సామీప్యత పరంగా ప్రతి రాష్ట్రం యొక్క "వాగ్దానం" అంచనా వేస్తుంది.
- శోధన వ్యూహం: అల్గోరిథం మూల్యాంకనం ఆధారంగా అత్యంత ఆశాజనక స్థితిని ఎంపిక చేస్తుంది heuristic. Best-First ఇది శోధన, A* శోధన లేదా శోధన వంటి శోధన వ్యూహాన్ని ఉపయోగిస్తుంది Greedy.
- రాష్ట్ర విస్తరణ: ఎంచుకున్న రాష్ట్రం దాని పొరుగు రాష్ట్రాలను రూపొందించడం ద్వారా విస్తరించబడుతుంది. వీరు తదుపరి దశకు సంభావ్య అభ్యర్థులు.
- పునరావృతం: ప్రక్రియ మళ్లీ పునరావృతమవుతుంది, లక్ష్య స్థితి కనుగొనబడే వరకు లేదా ముగింపు పరిస్థితిని చేరుకునే వరకు రాష్ట్రాలను ఎంచుకోవడం మరియు విస్తరిస్తుంది.
ఉదాహరణ: ట్రావెలింగ్ సేల్స్మ్యాన్ సమస్య(TSP)
ట్రావెలింగ్ సేల్స్మ్యాన్ సమస్యను పరిగణించండి, ఇక్కడ సేల్స్మ్యాన్ నగరాల సమితిని సందర్శించి, ప్రయాణించిన మొత్తం దూరాన్ని తగ్గించుకుంటూ ప్రారంభ నగరానికి తిరిగి రావాలి. ఒక heuristic విధానం సమీప పొరుగు అల్గోరిథం కావచ్చు:
- యాదృచ్ఛిక నగరంలో ప్రారంభించండి.
- ప్రతి దశలో, సమీప సందర్శించని నగరాన్ని తదుపరి గమ్యస్థానంగా ఎంచుకోండి.
- అన్ని నగరాలను సందర్శించే వరకు పునరావృతం చేయండి, ఆపై ప్రారంభ నగరానికి తిరిగి వెళ్లండి.
C++లో కోడ్ ఉదాహరణ
ఈ ఉదాహరణలో, ట్రావెలింగ్ సేల్స్మ్యాన్ సమస్యను పరిష్కరించడానికి సమీప పొరుగు అల్గోరిథం ఉపయోగించబడుతుంది. ఇది heuristic ప్రతి దశలో సమీపంలోని సందర్శించని నగరాన్ని ఎంచుకునే విధానం, దీని ఫలితంగా తరచుగా సరైనదానికి దగ్గరగా ఉండే పరిష్కారం లభిస్తుంది.