C++ માં Deque અથવા ડબલ-એન્ડેડ કતાર પરનું ઊંડાણપૂર્વકનું ટ્યુટોરીયલ. ટ્યુટોરીયલ સમજાવે છે કે ડેક શું છે, મૂળભૂત કામગીરી, C++ & જાવા અમલીકરણ અને એપ્લિકેશન્સ:
ડબલ એન્ડેડ કતાર અથવા ફક્ત "ડેક" કહેવાય છે તે કતારનું સામાન્યકૃત સંસ્કરણ છે.
કતાર અને ડેક વચ્ચેનો તફાવત એ છે કે તે FIFO ને અનુસરતું નથી. (ફર્સ્ટ ઇન, ફર્સ્ટ આઉટ) અભિગમ. Deque ની બીજી વિશેષતા એ છે કે આપણે આગળના અથવા પાછળના છેડામાંથી તત્વો દાખલ અને દૂર કરી શકીએ છીએ.
ડબલ એન્ડેડ કતાર વર્ગીકરણ
ડેક કરી શકે છે નીચે પ્રમાણે વર્ગીકૃત કરવામાં આવશે:
ઇનપુટ-પ્રતિબંધિત ડેક: ઇનપુટ-પ્રતિબંધિતમાં, કાઢી નાખવાનું બંને છેડેથી કરી શકાય છે પરંતુ નિવેશ ફક્ત પાછળના છેડે જ કરી શકાય છે. કતાર.
આઉટપુટ-પ્રતિબંધિત ડેક: આઉટપુટ-પ્રતિબંધિત કતારમાં, નિવેશ બંને છેડેથી કરી શકાય છે પરંતુ કાઢી નાખવાની પ્રક્રિયા ફક્ત એક છેડે એટલે કે કતારના આગળના છેડે કરવામાં આવે છે.
અમે ડેકનો ઉપયોગ કરીને સ્ટેક્સ અને કતારોનો અમલ પણ કરી શકીએ છીએ.
મૂળભૂત ડેક ઓપરેશન્સ
નીચે આપેલ મૂળભૂત કામગીરી છે જે ડેક પર કરી શકાય છે.
- સામે દાખલ કરો: ડેકની આગળની બાજુએ એક આઇટમ દાખલ કરો અથવા ઉમેરો.
- છેલ્લું દાખલ કરો: એક આઇટમ દાખલ કરો અથવા ઉમેરો ડેકનો પાછળનો ભાગ.
- ડિલીટફ્રન્ટ: કતારના આગળના ભાગમાંથી આઇટમ કાઢી નાખો અથવા દૂર કરો.
- છેલ્લું કાઢી નાખો: કાઢી નાખો અથવા દૂર કરો ની પાછળની વસ્તુકતાર.
- ગેટફ્રન્ટ: ડેકમાં આગળની આઇટમ પુનઃપ્રાપ્ત કરે છે.
- ગેટ લાસ્ટ: કતારમાં છેલ્લી આઇટમ પુનઃપ્રાપ્ત કરે છે.
- ખાલી છે: તપાસ કરે છે કે શું ડેક ખાલી છે.
- પૂર્ણ છે: ડેક ભરેલું છે કે કેમ તે તપાસે છે.
ડેક ઇલસ્ટ્રેશન
ખાલી ડેક નીચે પ્રમાણે રજૂ થાય છે:
13>
આગળ, અમે આગળના ભાગમાં એલિમેન્ટ 1 દાખલ કરીએ છીએ.
હવે, અમે પાછળના ભાગમાં તત્વ 3 દાખલ કરીએ છીએ.
આગળ, અમે તત્વ 5 ને આગળના ભાગમાં ઉમેરીએ છીએ અને જ્યારે આગળના બિંદુઓને વધારીએ છીએ 4.
પછી, આપણે એલિમેન્ટ્સ 7 પાછળના ભાગમાં અને 9 આગળના ભાગમાં દાખલ કરીએ છીએ. નીચે બતાવ્યા પ્રમાણે ડેક દેખાશે.
આગળ, ચાલો આગળથી એક તત્વ દૂર કરીએ.
આ રીતે, આપણે જોઈએ છીએ કે જ્યારે એલિમેન્ટ્સ આગળના ભાગમાં નાખવામાં આવે છે, ત્યારે આગળની સ્થિતિ ઘટતી જાય છે જ્યારે એલિમેન્ટને દૂર કરવામાં આવે ત્યારે તેમાં વધારો થાય છે. પાછળના છેડા માટે, નિવેશ માટે પોઝિશનમાં વધારો કરવામાં આવે છે અને દૂર કરવા માટે ઘટાડો કરવામાં આવે છે .
ડેક અમલીકરણ
C++ ડેક અમલીકરણ
અમે ડેકનો અમલ કરી શકીએ છીએ C++ માં એરે તેમજ લિંક કરેલ સૂચિનો ઉપયોગ કરીને. આ સિવાય, સ્ટાન્ડર્ડ ટેમ્પલેટ લાઇબ્રેરી (STL) પાસે એક વર્ગ “deque” છે જે આ ડેટા સ્ટ્રક્ચર માટેના તમામ કાર્યોનો અમલ કરે છે.
ડેકનું એરે અમલીકરણ નીચે આપેલ છે. તે ડબલ-એન્ડેડ કતાર હોવાથી અમે તેના માટે પરિપત્ર એરેનો ઉપયોગ કર્યો છેલાગુ deque 3
deleterear પછી, rear =
તત્વ 5 ને આગળના છેડે દાખલ કરવું
deque 5 નું આગળનું તત્વ
ડિલીટફ્રન્ટ પછી, ફ્રન્ટ = 3
Java Deque અમલીકરણ
જાવામાં ડેક ઈન્ટરફેસ, "java.util.Deque" "java.util.Queue" ઈન્ટરફેસમાંથી ઉતરી આવ્યું છે. ડેકનો ઉપયોગ કતાર (ફર્સ્ટ ઇન, ફર્સ્ટ આઉટ) અથવા સ્ટેક (લાસ્ટ ઇન, ફર્સ્ટ આઉટ) તરીકે થઈ શકે છે. આ અમલીકરણો લિંક કરેલ સૂચિ કરતાં વધુ ઝડપથી કાર્ય કરે છે.
જાવામાં ડેક ઈન્ટરફેસ માટે નીચે આપેલ વંશવેલો છે.
આપણે જાવામાં ડેક ઈન્ટરફેસ વિશેના કેટલાક મુદ્દાઓ યાદ રાખવાની જરૂર છે:
- અમલીકરણ થ્રેડ-સલામત નથી કારણ કે ત્યાં કોઈ બાહ્ય સિંક્રનાઇઝેશન નથી.
- ડેક એવું નથી બહુવિધ થ્રેડો દ્વારા સમન્વયને સમર્થન આપે છે.
- એરેનો ઉપયોગ કરીને અમલમાં મૂકાયેલ ડેક NULL તત્વોના ઉપયોગને મંજૂરી આપતું નથી.
- એરેને પ્રતિબંધ-મુક્ત ક્ષમતા અને માપ બદલી શકાય તેવા એરે સપોર્ટ સાથે, જરૂરિયાતો અનુસાર વધવાની મંજૂરી છે. બે સૌથી મહત્વપૂર્ણ લક્ષણો છે.
ડેક ઈન્ટરફેસ દ્વારા આધારભૂત વિવિધ પદ્ધતિઓ નીચે મુજબ છે:
નં. | પદ્ધતિ | વર્ણન |
---|---|---|
1 | એડ(તત્વ) | પૂંછડીમાં એક તત્વ ઉમેરે છે. |
2 | addFirst(element) | માં એક ઘટક ઉમેરે છેહેડ/ફ્રન્ટ. |
3 | એડ લાસ્ટ(તત્વ) | પૂંછડી/પાછળમાં એક ઘટક ઉમેરે છે. | 4 | ઑફર(તત્વ) | પૂંછડીમાં એક ઘટક ઉમેરે છે; જો નિવેશ સફળ થયો હતો કે કેમ તે દર્શાવવા માટે બુલિયન મૂલ્ય પરત કરે છે. |
5 | offerFirst(element) | હેડમાં એક ઘટક ઉમેરે છે; જો નિવેશ સફળ હતો કે કેમ તે દર્શાવવા માટે બુલિયન મૂલ્ય પરત કરે છે. |
6 | offerLast(element) | ટેલમાં એક ઘટક ઉમેરે છે; જો નિવેશ સફળ હતો કે કેમ તે દર્શાવવા માટે બુલિયન મૂલ્ય પરત કરે છે. |
7 | ઇટરરેટર() | ડેક માટે ઇટરરેટર પરત કરે છે. |
8 | dscendingIterator() | એક પુનરાવર્તક પરત કરે છે જે આ ડેક માટે વિપરીત ક્રમ ધરાવે છે. |
9 | પુશ(તત્વ) | ડેકના હેડમાં એક તત્વ ઉમેરે છે. |
10 | પોપ(તત્વ) | એક તત્વને ડેકના હેડમાંથી દૂર કરે છે અને તેને પરત કરે છે. |
11 | રીમૂવ ફર્સ્ટ() | પર ઘટકને દૂર કરે છે ડેકનું માથું. |
12 | removeLast() | ડેકની પૂંછડી પરના તત્વને દૂર કરે છે. |
13 | પોલ() | ડેકના પ્રથમ ઘટકને પુનઃપ્રાપ્ત કરે છે અને દૂર કરે છે (ડેકના વડા દ્વારા રજૂ થાય છે); જો ડેક ખાલી હોય તો NULL પરત કરે છે. |
14 | પોલ ફર્સ્ટ() | આ ડેકનું પ્રથમ ઘટક મેળવે છે અને દૂર કરે છે; જો આ ડેક હોય તો નલ પરત કરે છેખાલી. |
15 | પોલ લાસ્ટ() | આ ડેકનું છેલ્લું ઘટક મેળવે છે અને દૂર કરે છે; જો આ ડેક ખાલી હોય તો નલ પરત કરે છે. |
16 | પીક() | પ્રદર્શિત કતારના હેડ(ડેકનું પ્રથમ તત્વ) પુનઃપ્રાપ્ત કરે છે આ ડેક દ્વારા; જો આ ડેક ખાલી હોય તો નલ પરત કરે છે. નોંધ: આ ઓપરેશન એલિમેન્ટને દૂર કરતું નથી. |
17 | પીક ફર્સ્ટ() | આ ડેકનું પ્રથમ તત્વ પુનઃપ્રાપ્ત કરે છે; જો આ ડેક ખાલી હોય તો નલ પરત કરે છે. નોંધ: આ ઑપરેશન એલિમેન્ટને દૂર કરતું નથી. |
18 | peekLast() | આ ડીકનું છેલ્લું ઘટક પુનઃપ્રાપ્ત કરે છે, અથવા જો આ ડીક ખાલી હોય તો નલ પરત કરે છે. નોંધ: આ ઑપરેશન એલિમેન્ટને દૂર કરતું નથી. |
નીચે આપેલ Java અમલીકરણ ઉપર ચર્ચા કરેલ વિવિધ કામગીરીઓ દર્શાવે છે.
import java.util.*; class Main { public static void main(String[] args) { Dequedeque = new LinkedList (); // We can add elements to the queue in various ways deque.add(1); // add to tail deque.addFirst(3); deque.addLast(5); deque.push(7); //add to head deque.offer(9); deque.offerFirst(11); deque.offerLast(13); System.out.println("The deque : " + deque + "\n"); // Iterate through the queue elements. System.out.println("Standard Iterator"); Iterator iterator = deque.iterator(); while (iterator.hasNext()) System.out.print(" " + iterator.next()); // Reverse order iterator Iterator reverse = deque.descendingIterator(); System.out.println("\nReverse Iterator"); while (reverse.hasNext()) System.out.print(" " + reverse.next()); // Peek returns the head, without deleting // it from the deque System.out.println("\n\nPeek " + deque.peek()); System.out.println("After peek: " + deque); // Pop returns the head, and removes it from // the deque System.out.println("\nPop " + deque.pop()); System.out.println("After pop: " + deque); // We can check if a specific element exists // in the deque System.out.println("\nContains element 3?: " + deque.contains(3)); // We can remove the first / last element. deque.removeFirst(); deque.removeLast(); System.out.println("Deque after removing " + "first and last elements: " + deque); } }
આઉટપુટ:
The deque : [11, 7, 3, 1, 5, 9, 13]
સ્ટાન્ડર્ડ ઇટરેટર
11 7 3 1 5 9 13
રિવર્સ ઇટરરેટર
13 9 5 1 3 7 1
પીક 11
પિક પછી: [11, 7, 3, 1, 5, 9, 13]
પૉપ 11
પૉપ પૉપ પછી: [7, 3, 1, 5, 9, 13]
તત્વ 3 સમાવે છે?: સાચું
પ્રથમ અને છેલ્લા તત્વોને દૂર કર્યા પછી ડેક: [3, 1, 5, 9]
ઉપરોક્ત પ્રોગ્રામમાં, અમે Java ના Deque ઈન્ટરફેસનો ઉપયોગ કર્યો છે અને અમે પૂર્ણાંક તત્વોની deque વ્યાખ્યાયિત કરી છે. પછી અમે આ ડેક પર વિવિધ ઑપરેશન કર્યા અને આ ઑપરેશન્સના પરિણામો આઉટપુટ કર્યાપ્રદર્શિત થાય છે.
એપ્લીકેશન્સ
નીચેની કેટલીક એપ્લીકેશનમાં ડીકનો ઉપયોગ કરી શકાય છે.
#1) શેડ્યુલિંગ એલ્ગોરિધમ: શેડ્યુલિંગ એલ્ગોરિધમ, "એ-સ્ટીલ શેડ્યુલિંગ એલ્ગોરિધમ" મલ્ટિપ્રોસેસર સિસ્ટમમાં વિવિધ પ્રોસેસરો માટે કાર્ય શેડ્યુલિંગનો અમલ કરે છે. આ અમલીકરણ ડેકનો ઉપયોગ કરે છે અને પ્રોસેસરને એક્ઝેક્યુશન માટે ડેકમાંથી પ્રથમ ઘટક મળે છે.
#2) પ્રવૃત્તિઓની સૂચિ પૂર્વવત્ કરો: સોફ્ટવેર એપ્લિકેશન્સમાં, અમારી પાસે ઘણી ક્રિયાઓ છે. એક "પૂર્વવત્ કરો" છે. જ્યારે આપણે ઘણી વખત પૂર્વવત્ ક્રિયા કરી છે, ત્યારે આ બધી ક્રિયાઓ સૂચિમાં સંગ્રહિત થાય છે. આ સૂચિને ડેક તરીકે જાળવવામાં આવે છે જેથી કરીને અમે કોઈપણ છેડેથી એન્ટ્રીઓ સરળતાથી ઉમેરી/દૂર કરી શકીએ.
#3) થોડા સમય પછી એન્ટ્રીઓ દૂર કરો: એપ્લિકેશન રિફ્રેશ તેમની સૂચિમાંની એન્ટ્રીઓ જેવી કે એપ્સ સ્ટોક એન્ટ્રીઓની યાદી આપે છે, વગેરે. આ એપ્સ થોડા સમય પછી એન્ટ્રીઓને દૂર કરે છે અને નવી એન્ટ્રીઓ પણ દાખલ કરે છે. આ ડેકનો ઉપયોગ કરીને કરવામાં આવે છે.
નિષ્કર્ષ
ડેક એ ડબલ-એન્ડેડ કતાર છે જે અમને કતારના બંને છેડા એટલે કે આગળ અને પાછળના ઘટકોને ઉમેરવા/દૂર કરવાની મંજૂરી આપે છે. ડેક એરે અથવા લિંક કરેલી સૂચિનો ઉપયોગ કરીને અમલમાં મૂકી શકાય છે. જો કે, અમારી પાસે સ્ટાન્ડર્ડ ટેમ્પલેટ લાઇબ્રેરી (STL) ક્લાસ પણ છે જે ડેકની વિવિધ કામગીરીનો અમલ કરે છે.
જાવામાં, અમારી પાસે ડેક ઈન્ટરફેસ છે જે ડેકને અમલમાં મૂકવા માટે કતાર ઈન્ટરફેસમાંથી વારસામાં મળેલ છે. Deque ના મૂળભૂત પ્રમાણભૂત કામગીરી ઉપરાંત, આ ઇન્ટરફેસ વિવિધને સપોર્ટ કરે છેઅન્ય કામગીરી કે જે Deque પર હાથ ધરવામાં આવી શકે છે.
Deque નો ઉપયોગ સામાન્ય રીતે એપ્લીકેશન માટે થાય છે કે જેને બંને છેડેથી તત્વો ઉમેરવા/દૂર કરવા જરૂરી હોય છે. તેનો ઉપયોગ મોટાભાગે મલ્ટી-પ્રોસેસર સિસ્ટમમાં પ્રોસેસરોના શેડ્યુલિંગમાં પણ થાય છે.
સંપૂર્ણ C++ તાલીમ શ્રેણી તપાસો