- Dosbarthiad Ciw Pen Dwbl
- Gweithrediadau Deque Sylfaenol
- Darlun Deque
- Gweithredu Deque
- Ceisiadau
- Casgliad
Diwtorial Manwl ar Ddeque neu Ciw Pen Dwbl yn C++. Tiwtorial yn esbonio Beth yw Deque, Gweithrediadau Sylfaenol, C++ & Gweithredu a Chymwysiadau Java:
Mae ciw dwbl neu a elwir yn syml “Deque” yn fersiwn gyffredinol o Ciw.
Y gwahaniaeth rhwng Ciw a Deque yw nad yw'n dilyn y FIFO (Cyntaf i Mewn, Cyntaf Allan). Ail nodwedd Deque yw y gallwn fewnosod a thynnu elfennau o naill ai ben blaen neu ben ôl.
Dosbarthiad Ciw Pen Dwbl
Deque can cael eu dosbarthu fel a ganlyn:
Deque Cyfyngedig Mewnbwn: Mewn mewnbwn-cyfyngedig, gellir dileu o'r ddau ben ond dim ond ar ben cefn y gellir ei fewnosod ciw.
Deque Cyfyngedig Allbwn: Yn y ciw â chyfyngiad allbwn, gellir mewnosod o'r ddau ben ond dim ond un pen sy'n cael ei ddileu h.y. pen blaen y ciw.
Gallwn hefyd weithredu staciau a chiwiau gan ddefnyddio deque.
Gweithrediadau Deque Sylfaenol
Mae'r canlynol yn weithrediadau sylfaenol y gellir eu cyflawni ar ddeque.
- mewnosod blaen: Mewnosod neu ychwanegu eitem ar flaen y deque.
- mewnosoder Diwethaf: Mewnosod neu ychwanegu eitem yn cefn y deque.
- deleteFront: Dileu neu dynnu'r eitem o flaen y ciw.
- dileer olaf: Dileu neu dynnu yr eitem o gefn yciw.
- getFront: Yn nôl yr eitem flaen yn y deque.
- getLast: Yn nôl yr eitem olaf yn y ciw.
- yn Wag: Gwirio a yw'r deque yn wag.
- yn Llawn: Gwirio a yw'r deque yn llawn.
Darlun Deque
Cynrychiolir deque gwag fel a ganlyn:
Nesaf, rydym yn mewnosod elfen 1 ar y blaen.
Nawr, rydyn ni'n mewnosod elfen 3 yn y cefn.
Nesaf, rydyn ni'n ychwanegu elfen 5 i'r tu blaen ac wrth gynyddu'r pwyntiau blaen i 4.
Yna, rydym yn mewnosod elfennau 7 yn y cefn a 9 yn y blaen. Bydd y deque yn edrych fel y dangosir isod.
Nesaf, gadewch i ni dynnu elfen o'r tu blaen.
Felly, gwelwn pan fydd yr elfennau'n cael eu mewnosod yn y blaen, mae'r safle blaen yn cael ei ostwng tra ei fod yn cynyddu pan fydd elfen yn cael ei thynnu. Ar gyfer y pen ôl, cynyddir y safle i'w fewnosod a'i ostwng ar gyfer tynnu .
Gweithredu Deque
C++ Gweithredu Deque
Gallwn weithredu deque yn C++ gan ddefnyddio araeau yn ogystal â rhestr gysylltiedig. Ar wahân i hyn, mae gan y Llyfrgell Templedi Safonol (STL) “ddec” dosbarth sy'n gweithredu'r holl swyddogaethau ar gyfer y strwythur data hwn.
Rhoddir gweithrediad arae'r deque isod. Gan ei fod yn giw pen dwbl rydym wedi defnyddio araeau crwn ar ei gyfergweithredu.
#includeusing namespace std; #define MAX_size 10 // Maximum size of array or Dequeue // Deque class class Deque { int array[MAX_size]; int front; int rear; int size; public : Deque(int size) { front = -1; rear = 0; this->size = size; } // Operations on Deque: void insertfront(int key); void insertrear(int key); void deletefront(); void deleterear(); int getFront(); int getRear(); // Check if Deque is full bool isFull() return ((front == 0 && rear == size-1) // Check if Deque is empty bool isEmpty(){ return (front == -1); } }; // Insert an element at front of the deque void Deque::insertfront(int key) { if (isFull()) { cout "Overflow!!\n" endl; return; } // If queue is initially empty,set front=rear=0; start of deque if (front == -1) { front = 0; rear = 0; } else if (front == 0) // front is first position of queue front = size - 1 ; else // decrement front 1 position front = front-1; array[front] = key ; // insert current element into Deque } // insert element at the rear end of deque void Deque ::insertrear(int key) { if (isFull()) { cout " Overflow!!\n " endl; return; } // If queue is initially empty,set front=rear=0; start of deque if (front == -1) { front = 0; rear = 0; } else if (rear == size-1) // rear is at last position of queue rear = 0; else // increment rear by 1 position rear = rear+1; array[rear] = key ; // insert current element into Deque } // Delete element at front of Deque void Deque ::deletefront() { if (isEmpty()) { cout "Queue Underflow!!\n" endl; return ; } // Deque has only one element if (front == rear) { front = -1; rear = -1; } else // back to initial position if (front == size -1) front = 0; else // remove current front value from Deque;increment front by 1 front = front+1; } // Delete element at rear end of Deque void Deque::deleterear() { if (isEmpty()) { cout " Underflow!!\n" endl ; return ; } // Deque has only one element if (front == rear) { front = -1; rear = -1; } else if (rear == 0) rear = size-1; else rear = rear-1; } // retrieve front element of Deque int Deque::getFront() { if (isEmpty()) { cout " Underflow!!\n" endl; return -1 ; } return array[front]; } // retrieve rear element of Deque int Deque::getRear() { if(isEmpty() || rear 0) { cout " Underflow!!\n" endl; return -1 ; } return array[rear]; } //main program int main() { Deque dq(5); cout "Insert element 1 at rear end \n"; dq.insertrear(1); cout "insert element 3 at rear end \n"; dq.insertrear(3); cout "rear element of deque " " " dq.getRear() endl; dq.deleterear(); cout "After deleterear, rear = " dq.getRear() endl; cout "inserting element 5 at front end \n"; dq.insertfront(5); cout "front element of deque " " " dq.getFront() endl; dq.deletefront(); cout "After deletefront, front = " dq.getFront() endl; return 0; }
Allbwn:
Mewnosod elfen 1 ar y pen cefn
mewnosod elfen 3 ar y cefn
elfen tu cefn deque 3
Ar ôl deleterear, cefn =
gosod elfen 5 yn y pen blaen
elfen blaen o deque 5
Ar ôl deletefront, blaen = 3
Gweithredu Deque Java
Mae'r rhyngwyneb deque yn Java, “java.util.Deque” yn deillio o ryngwyneb “java.util.Queue”. Gellir defnyddio deque fel ciw (Cyntaf i Mewn, Cyntaf Allan) neu bentwr (Olaf i Mewn, Cyntaf Allan). Mae'r gweithrediadau hyn yn gweithio'n gyflymach na'r rhestr gysylltiedig.
Isod mae hierarchaeth y rhyngwyneb Deque yn Java.
>Mae angen inni gofio ychydig o bwyntiau am y rhyngwyneb Deque yn Java:
- Nid yw'r gweithrediad yn edau-ddiogel gan nad oes cydamseriad allanol.
- Nid yw Deque yn cefnogi concurrency gan edefynau lluosog.
- Nid yw Deque's a weithredir gan ddefnyddio araeau yn caniatáu defnyddio elfennau NULL.
- Caniateir i araeau dyfu yn unol â'r gofynion, gyda chynhwysedd heb gyfyngiad a chefnogaeth arae y gellir ei hailfeintio sef y ddwy nodwedd bwysicaf.
Yn dilyn mae'r gwahanol ddulliau a gefnogir gan y rhyngwyneb Deque:
Na. | Dull | Disgrifiad |
---|---|---|
1 | ychwanegu(elfen) | Yn ychwanegu elfen at y gynffon. |
2 | ychwaneguFirst(elfen) | Yn ychwanegu elfen at ypen/blaen. | 3 | ychwanegu Olaf(elfen) | Ychwanegu elfen i'r gynffon/cefn. | 244 | cynnig(elfen) | Yn ychwanegu elfen at y gynffon; yn dychwelyd gwerth boolaidd i ddangos a oedd y mewnosodiad yn llwyddiannus. |
5 | cynnigFirst(elfen) | Yn ychwanegu elfen at y pen; yn dychwelyd gwerth boolaidd i ddangos a oedd y mewnosodiad yn llwyddiannus. |
6 | cynnigLast(elfen) | Yn ychwanegu elfen at y gynffon; yn dychwelyd gwerth boolaidd i ddangos a oedd y mewnosodiad yn llwyddiannus. |
7 | iterator() | Yn dychwelyd iterator ar gyfer y deque. |
8 | Iterator disgynnol() | Yn dychwelyd iterator sydd â'r drefn wrthdroi ar gyfer y deque hwn. |
9 | push(elfen) | Yn ychwanegu elfen at ben y deque. |
10 | pop(elfen) | Yn tynnu elfen o ben y deque ac yn ei dychwelyd. pen y deque. |
12 | tynnuLast() | Yn tynnu'r elfen ar gynffon y deque. |
13 | pôl() | Yn adalw ac yn dileu elfen gyntaf y deque (a gynrychiolir gan ben y deque); yn dychwelyd NULL os yw'r deque yn wag. |
14 | pollFirst() | Yn nôl a dileu elfen gyntaf y deque hwn; yn dychwelyd null os yw'r deque hwnwag. |
polLast() | Yn nôl a dileu elfen olaf y deque hwn; yn dychwelyd null os yw'r deque hwn yn wag. | |
16 | peek() | Yn nôl pen (elfen gyntaf y deque) y ciw a gynrychiolir gan y deque hwn; yn dychwelyd null os yw'r deque hwn yn wag. Sylwer: Nid yw'r weithred hon yn tynnu'r elfen. |
17 | peekFirst() | Yn adalw elfen gyntaf y deque hwn; yn dychwelyd null os yw'r deque hwn yn wag. Sylwer: Nid yw'r weithred hon yn tynnu'r elfen. |
18 | peekLast() | Yn nôl elfen olaf y deque hwn, neu'n dychwelyd null os yw'r deque hwn yn wag. Sylwer: Nid yw'r weithred hon yn tynnu'r elfen. |
Mae'r gweithrediad Java canlynol yn dangos y gweithrediadau amrywiol a drafodwyd uchod.
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); } }
Allbwn:
Y deque : [11, 7, 3, 1, 5, 9, 13]
Iterator Safonol
11 7 3 1 5 9 13
Iterator Cwith
13 9 5 1 3 7 1
Peek 11
Ar ôl cip: [11, 7, 3, 1, 5, 9, 13]
Pop 11
Ar ol pop: [7, 3, 1, 5, 9, 13]
Yn cynnwys elfen 3?: gwir
Deque ar ôl tynnu elfennau cyntaf ac olaf: [3, 1, 5, 9]
3
Yn y rhaglen uchod, rydym wedi defnyddio rhyngwyneb Deque Java ac rydym wedi diffinio deque o elfennau cyfanrif. Yna fe wnaethom berfformio amrywiol weithrediadau ar y deque hwn ac allbwn canlyniadau'r gweithrediadau hyn ywarddangos.
Ceisiadau
Gellir defnyddio Deque yn rhai o'r rhaglenni canlynol.
#1) Algorithm Amserlennu: Mae algorithm amserlennu, “algorithm amserlennu A-steal” yn gweithredu amserlennu tasgau ar gyfer proseswyr amrywiol yn y system amlbrosesydd. Mae'r gweithrediad hwn yn defnyddio deque ac mae'r prosesydd yn cael yr elfen gyntaf o'r deque ar gyfer cyflawni.
#2) Dadwneud Rhestr O Weithgareddau: Mewn rhaglenni meddalwedd, mae gennym lawer o gamau gweithredu. Un yw “dadwneud”. Pan fyddwn wedi dad-wneud gweithred droeon, mae'r holl gamau hyn yn cael eu storio mewn rhestr. Mae'r rhestr hon yn cael ei chynnal fel deque fel y gallwn ychwanegu/dileu cofnodion o unrhyw ddiwedd yn rhwydd.
#3) Dileu'r Cofnodion Ar ôl Peth Amser: Adnewyddu apiau cofnodion yn eu rhestr fel apps rhestru'r cofnodion stoc, ac ati Mae'r apps hyn yn dileu'r cofnodion ar ôl peth amser a hefyd yn mewnosod cofnodion newydd. Gwneir hyn gan ddefnyddio deque.
Casgliad
Ciw dau ben yw Deque sy'n ein galluogi i ychwanegu/dileu elfennau o ddau ben y ciw, h.y. blaen a chefn, y ciw. Gellir gweithredu deque gan ddefnyddio araeau neu restrau cysylltiedig. Fodd bynnag, mae gennym hefyd ddosbarth Llyfrgell Templed Safonol (STL) sy'n gweithredu amrywiol weithrediadau'r Deque.
Yn Java, mae gennym ryngwyneb Deque sy'n cael ei etifeddu o'r rhyngwyneb ciw i weithredu Deque. Ar wahân i weithrediadau safonol sylfaenol y Deque, mae'r rhyngwyneb hwn yn cefnogi amrywiolgweithrediadau eraill y gellir eu cyflawni ar Deque.
Deque yn cael ei ddefnyddio'n gyffredinol ar gyfer rhaglenni sydd angen ychwanegu/tynnu elfennau o'r ddau ben. Fe'i defnyddir yn bennaf hefyd wrth amserlennu proseswyr mewn systemau aml-brosesydd.
Edrychwch ar Gyfres Hyfforddiant C++ Cyflawn