Jump to content

క్యూ డేటా నిర్మాణం

వికీపీడియా నుండి
క్యూ
తరహాడేటా నిర్మాణం
స్థాపనడోనాల్డ్ నుత్ (నిర్వచనాన్ని అధికారికం చేసిన మొదటిది)
ప్రధానకేంద్రముకాల్టెక్‌లో కనుగొనబడింది

కంప్యూటర్ సైన్స్లో, ఒక క్యూ అనేది ఒక సరళ నిర్మాణం, ఇది కార్యకలాపాలను నిర్వహించే ఒక నిర్దిష్ట క్రమాన్ని అనుసరిస్తుంది ఆర్డర్ "ఫస్ట్ ఇన్ ఫస్ట్ అవుట్" (FIFO).[1] రోజువారీ జీవితంలో ఒక క్యూను వివరించడానికి ఒక మంచి ఉదాహరణ, మొదట వచ్చిన వినియోగదారుడు మొదట వడ్డించే వనరు కోసం వేచి ఉన్న వినియోగదారుల క్యూ. మూలకాలను తొలగించడంలో పైల్ క్యూల మధ్య వ్యత్యాసం ఉంది. చివరిగా జోడించిన అంశాన్ని పైల్ తొలగిస్తాము; క్యూలో, మేము మొదట జోడించిన అంశాన్ని తీసివేస్తాము. FIFO డేటా నిర్మాణంలో, క్యూలో చేర్చబడిన మొదటి మూలకం తొలగించబడిన మొదటిది. క్రొత్త మూలకాన్ని జోడించిన తర్వాత, క్రొత్త మూలకాన్ని తొలగించే ముందు తొలగించబడిన అన్ని మూలకాలను తొలగించాల్సిన అవసరానికి ఇది సమానం. తరచుగా ఒక పీక్ లేదా ఫ్రంట్ ఆపరేషన్ కూడా నమోదు చేయబడుతుంది, ఫ్రంట్ ఎలిమెంట్ విలువను డీక్యూ చేయకుండా తిరిగి ఇస్తుంది. క్యూ అనేది సరళ డేటా నిర్మాణానికి ఉదాహరణ, లేదా మరింత వియుక్తంగా ఒక వరుస సేకరణ.

అమలు

[మార్చు]

ప్రధానంగా కింది నాలుగు ప్రాథమిక కార్యకలాపాలు క్యూలో నిర్వహించబడతాయి:[2]

  • ఎన్క్యూ: క్యూలో ఒక అంశాన్ని జోడిస్తుంది. క్యూ నిండి ఉంటే, అది ఓవర్‌ఫ్లో కండిషన్ అని అంటారు.
  • డీక్యూ: క్యూ నుండి ఒక అంశాన్ని తొలగిస్తుంది. అంశాలు నెట్టివేయబడిన అదే క్రమంలో పాప్ చేయబడతాయి. క్యూ ఖాళీగా ఉంటే, అది అండర్ ఫ్లో కండిషన్ అని అంటారు.
    ఈ రేఖాచిత్రం క్యూ ప్రాథమిక నిర్మాణాన్ని హైలైట్ చేస్తుంది.
  • ముందు: క్యూ నుండి ముందు అంశాన్ని పొందండి.
  • వెనుక: క్యూ నుండి చివరి అంశాన్ని పొందండి.

ఎన్క్యూ

[మార్చు]

ఎన్క్యూ ఆపరేషన్ క్యూలు ముందు వెనుక రెండు డేటా పాయింటర్లను నిర్వహిస్తాయి. అందువల్ల, దాని కార్యకలాపాలు పైల్ కంటే అమలు చేయడం చాలా కష్టం. డేటాను క్యూలో ఉంచడానికి (చొప్పించడానికి) క్రింది చర్యలు తీసుకోవాలి -

  1. క్యూ నిండి ఉందో లేదో తనిఖీ చేయండి.
  2. క్యూ నిండి ఉంటే, ఓవర్‌ఫ్లో లోపం ఉత్పత్తి చేసి నిష్క్రమించండి.
  3. క్యూ పూర్తి కాకపోతే, తదుపరి ఖాళీ స్థలాన్ని సూచించడానికి ఇంక్రిమెంట్ వెనుక పాయింటర్.
  4. వెనుక స్థానానికి సూచించే క్యూ స్థానానికి డేటా మూలకాన్ని జోడించండి.
  5. తిరిగి విజయం.
ఎన ఆపరషన  అలి
ి
ఎన ()
 ింి 
ిటర ఓవర
ిం
   + 1
 []. 
ి ిిి
ిం ి

డీక్యూ

[మార్చు]

డీక్యూ ఆపరేషన్ క్యూ నుండి డేటాను యాక్సెస్ చేయడం రెండు పనుల ప్రక్రియ - ముందు సూచించే డేటాను యాక్సెస్ చేయండి యాక్సెస్ తర్వాత డేటాను తొలగించండి. డీక్యూ ఆపరేషన్ చేయడానికి క్రింది చర్యలు తీసుకుంటారు -

  1. క్యూ ఖాళీగా ఉందో లేదో తనిఖీ చేయండి.
  2. క్యూ ఖాళీగా ఉంటే, అండర్ఫ్లో లోపం ఉత్పత్తి చేసి నిష్క్రమించండి.
  3. క్యూ ఖాళీగా లేకపోతే, ముందు సూచించే డేటాను యాక్సెస్ చేయండి.
  4. తదుపరి అందుబాటులో ఉన్న డేటా మూలకాన్ని సూచించడానికి ఫ్రంట్ పాయింటర్ పెంచండి.
  5. తిరిగి విజయం.
ి 
  
ిిి రవ
ిం
 =  [ుం]
ుం  ుం + 1
ి ిిి
ిం ి

ముందు

[మార్చు]

ముందు ఆపరేషన్ క్యూ ముందు భాగంలో మూలకాన్ని అందిస్తుంది. ఇది తదుపరి ప్రాసెస్ చేయబడే మూలకం. దీన్ని q [ముందు] ద్వారా సులభంగా యాక్సెస్ చేయవచ్చు, ఇక్కడ 'ఫ్రంట్' అనేది మొదటి మూలకానికి సూచించే పాయింటర్ 'q' అనేది క్యూను అమలు చేయడానికి ఉపయోగించే శ్రేణి.

వెనుక

[మార్చు]

వెనుక ఆపరేషన్ క్యూ వెనుక భాగంలో మూలకాన్ని అందిస్తుంది. చివరిగా ప్రాసెస్ చేయబడే మూలకం ఇది. Q [వెనుక] ద్వారా దీన్ని సులభంగా యాక్సెస్ చేయవచ్చు, ఇక్కడ 'వెనుక' అనేది చివరి మూలకాన్ని సూచించే పాయింటర్ 'q' అనేది క్యూను అమలు చేయడానికి ఉపయోగించే శ్రేణి.

పూర్తిగా ఫంక్షనల్ అమలు

[మార్చు]

క్యూలను పూర్తిగా పనిచేసే డేటా నిర్మాణంగా[3] కూడా అమలు చేయవచ్చు. మలు రెండు వెర్షన్లు ఉన్నాయి. మొదటిది, రియల్ టైమ్ క్యూ[4] అని పిలుస్తారు, క్రింద ఇవ్వబడినది, క్యూ O (1) చెత్త-సమయ కార్యకలాపాలతో నిరంతరాయంగా ఉండటానికి అనుమతిస్తుంది, కానీ జ్ఞాపకశక్తితో సోమరితనం జాబితాలు అవసరం.

క్యూ వైవిధ్యాలు

[మార్చు]

ప్రామాణిక క్యూ డేటా నిర్మాణం క్రింది వైవిధ్యాలను కలిగి ఉంది:[5]

  1. డబుల్ ఎండ్ క్యూ
  2. వృత్తాకార క్యూ
    డబుల్ ఎండ్ క్యూ

డబుల్ ఎండ్ క్యూ

[మార్చు]

ప్రామాణిక క్యూలో, ఒక అక్షరం వెనుక భాగంలో చొప్పించబడింది ముందు భాగంలో తొలగించబడుతుంది. ఏదేమైనా, డబుల్ ఎండ్ క్యూలో, క్యూ ముందు వెనుక రెండింటి నుండి అక్షరాలను చొప్పించి తొలగించవచ్చు.

వృత్తాకార క్యూలు

[మార్చు]

వృత్తాకార క్యూ అనేది ప్రామాణిక క్యూ నిర్మాణంపై మెరుగుదల. ప్రామాణిక క్యూలో, ఒక మూలకం తొలగించబడినప్పుడు, ఖాళీ స్థలం తిరిగి ఉపయోగించబడదు. అయినప్పటికీ, వృత్తాకార క్యూలో, ఖాళీ స్థలాలు తిరిగి ఉపయోగించబడతాయి.

మూలకాలను చొప్పించేటప్పుడు, మీరు శ్రేణి చివరకి చేరుకున్నప్పుడు మీరు మరొక మూలకాన్ని చొప్పించాల్సిన అవసరం వచ్చినప్పుడు, మీరు ఆ మూలకాన్ని ప్రారంభంలో చొప్పించాలి (మొదటి మూలకం తొలగించబడింది స్థలం ఖాళీగా ఉంది).

క్యూ అనువర్తనాలు

[మార్చు]

కంప్యూటర్ ప్రోగ్రామ్‌లలో క్యూలు సర్వసాధారణం, ఇక్కడ అవి డేటా స్ట్రక్చర్‌లతో పాటు యాక్సెస్ నిత్యకృత్యాలతో, ఒక నైరూప్య డేటా స్ట్రక్చర్‌గా లేదా ఆబ్జెక్ట్-ఓరియెంటెడ్ భాషల్లో క్లాస్‌లుగా అమలు చేయబడతాయి. సాధారణ అమలులు వృత్తాకార బఫర్‌లు లింక్డ్ జాబితాలు. కంప్యూటర్ సైన్స్, రవాణా కార్యకలాపాల పరిశోధనలలో క్యూలు సేవలను అందిస్తాయి, ఇక్కడ డేటా, వస్తువులు, వ్యక్తులు లేదా సంఘటనలు వంటి వివిధ సంస్థలు నిల్వ చేయబడతాయి తరువాత ప్రాసెస్ చేయబడతాయి. ఈ సందర్భాలలో, క్యూ బఫర్ పనితీరును నిర్వహిస్తుంది. క్యూల మరొక ఉపయోగం వెడల్పు-మొదటి శోధన అమలులో ఉంది. ప్యూటర్ సైన్స్ మరెన్నో రంగాలలో విస్తరించి ఉన్న అనేక ఇతర పనులలో కూడా క్యూ ఉపయోగించబడుతుంది. వాస్తవ ప్రపంచ అనువర్తనాలలో కొన్ని క్రింద ఇవ్వబడ్డాయి:[6]

  • ప్రింటర్, CPU టాస్క్ షెడ్యూలింగ్ మొదలైన ఒకే భాగస్వామ్య వనరుపై అభ్యర్థనలను అందిస్తోంది.
  • నిజ జీవిత దృష్టాంతంలో, సేవా ప్రతినిధి ఉచితం అయ్యే వరకు కాల్ సెంటర్ ఫోన్ వ్యవస్థలు వారిని పిలుస్తున్న వ్యక్తులను క్రమం తప్పకుండా ఉంచడానికి క్యూలను ఉపయోగిస్తాయి.
  • రియల్ టైమ్ సిస్టమ్స్‌లో అంతరాయాల నిర్వహణ. అంతరాయాలు వచ్చినప్పుడు అదే క్రమంలో నిర్వహించబడతాయి, మొదట మొదట వడ్డిస్తారు.

సంక్లిష్టత విశ్లేషణ

[మార్చు]

సరళ డేటా సంక్లిష్టతను కొనసాగిస్తూ క్యూ డేటా నిర్మాణం వినియోగదారుని దాని కీ ఆపరేషన్లను (ఎన్క్యూ డీక్యూ)[6] స్థిరమైన సమయంలో నిర్వహించడానికి అనుమతిస్తుంది. క్యూ సంక్లిష్టత విశ్లేషణను సంగ్రహించే పట్టిక క్రింద ఇవ్వబడింది.

క్యూ
పెద్ద O సంజ్ఞామానం లో సమయం సంక్లిష్టత
అల్గోరిథం సగటు చెత్త కేసు
స్థలం O(n) O(n)
వెతకండి O(n) O(n)
చొప్పించు O(1) O(1)
తొలగించు O(1) O(1)

మరింత చదవడానికి

[మార్చు]

మూలాలు

[మార్చు]
  1. "Queue (Java Platform SE 7 )". docs.oracle.com. Retrieved 2020-08-24.
  2. Chik, Adam. Stack & Queue. Pittsburgh: CMU.
  3. Okasaki, Chris (1996). Purely Functional Data Structures. Pittsburgh: CMU. pp. 1–162.
  4. Hood, Robert T.; Melville, Robert C. (1980). "Real Time Queue Operations in Pure LISP". Cornell (in అమెరికన్ ఇంగ్లీష్).
  5. "Basics of Queues Tutorials & Notes | Data Structures". HackerEarth (in ఇంగ్లీష్). Retrieved 2020-08-24.
  6. 6.0 6.1 "Queue Data Structure | Studytonight". www.studytonight.com. Retrieved 2020-08-24.