Oideachadh domhainn air Deque no Ciudha le dà cheann ann an C++. Tha an oideachadh a’ mìneachadh Dè a th’ ann an Deque, Obrachaidhean Bunaiteach, C ++ & Gnìomhachadh agus Iarrtasan Java:
Is e tionndadh coitcheann de Ciudha a th’ ann an ciudha dùbailte no dìreach ris an canar “Deque”.
Is e an diofar eadar Ciudha is Deque nach eil e a’ leantainn an FIFO (An toiseach a-steach, a’ chiad dol a-mach). Is e an dàrna feart de Deque gun urrainn dhuinn eileamaidean a chuir a-steach agus a thoirt air falbh bho cheann aghaidh no ceann cùil. a bhith air an seòrsachadh mar a leanas:
Meud cuibhrichte le cur-a-steach: Ann an cuingealachadh cuir a-steach, faodar cuir às bhon dà cheann ach chan urrainnear cuir a-steach ach aig ceann cùil an ciudha.
Meud cuibhrichte le toradh: Anns a’ chiudha cuibhrichte le toradh, faodar cuir a-steach a dhèanamh bhon dà cheann ach chan eil an sguabadh às ach aig aon cheann i.e. ceann aghaidh na ciudha.
'S urrainn dhuinn stacan agus ciudha a chur an sàs le deque cuideachd.
Obraichean Bunaiteach Deque
Seo na leanas na h-obraichean bunaiteach a ghabhas dèanamh air deque.
- cuir a-steach aghaidh: Cuir a-steach no cuir rud ris air beulaibh an deic.
- cuir a-steach mu dheireadh: Cuir a-steach no cuir rud ris aig cùl na deque.
- sguab àsFront: Sguab às no thoir air falbh an rud air beulaibh a' chiudha.
- sguab às mu dheireadh: Sguab às no thoir air falbh an nì bho chùl anciudha.
- getFront: Faigh an rud aghaidh san deic.
- getLast: Aisig an rud mu dheireadh sa chiudha.
- Falamh: Dèan cinnteach a bheil an deque falamh.
- IsFull: Dèan cinnteach a bheil an deque làn.
Deque Illustration
Tha deic falamh air a riochdachadh mar a leanas:
An ath rud, cuiridh sinn a-steach eileamaid 1 air an aghaidh.
A-nis, cuiridh sinn a-steach eileamaid 3 aig a’ chùl.
An ath rud, cuiridh sinn eileamaid 5 ris an aghaidh agus nuair a mheudaicheas sinn na puingean toisich gu 4.
An uairsin, cuiridh sinn a-steach eileamaidean 7 aig a’ chùl agus 9 aig an aghaidh. Seallaidh an deque mar a chithear gu h-ìosal.
Air adhart, leig dhuinn eileamaid a thoirt air falbh on aghaidh.
Mar sin, chì sinn nuair a thèid na h-eileamaidean a chuir a-steach aig an aghaidh, gu bheil an suidheachadh aghaidh air a lughdachadh fhad ‘s a tha e air àrdachadh nuair a thèid eileamaid a thoirt air falbh. Airson a’ cheann chùil, tha an suidheachadh air a mheudachadh airson a chuir a-steach agus air a lughdachadh airson a thoirt air falbh .
Gnìomhachadh Deque
C++ Buileachadh Deque
Is urrainn dhuinn deque a chuir an gnìomh ann an C ++ a’ cleachdadh arrays a bharrachd air liosta ceangailte. A bharrachd air an seo, tha “deque” clas aig an Leabharlann Teamplaid Coitcheann (STL) a bhios a’ cur an gnìomh a h-uile gnìomh airson an structair dàta seo.
Tha buileachadh sreath an deque air a thoirt seachad gu h-ìosal. Leis gur e ciudha le dà cheann a th’ ann tha sinn air arrays cruinn a chleachdadh airsonbuileachadh.
#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; }
Toradh:
Cuir a-steach eileamaid 1 aig deireadh
cuir a-steach eileamaid 3 aig cúl deireadh
eileamaid cùil de deque 3
Às dèidh deeterear, cùl =
a’ cur a-steach eileamaid 5 aig a’ cheann aghaidh
aghaidh eileamaid de deque 5
An dèidh deletefront, aghaidh = 3
Cur an gnìomh Java Deque
Tha an eadar-aghaidh deque ann an Java, “java.util.Deque” a’ tighinn bhon eadar-aghaidh “java.util.Queue”. Faodar deque a chleachdadh mar ciudha (Ciad a-steach, Ciad a-mach) no stac (Last In, First Out). Bidh na gnìomhan seo ag obair nas luaithe na an liosta ceangailte.
Gu h-ìosal tha an rangachd airson an eadar-aghaidh Deque ann an Java.
> Feumaidh sinn cuimhneachadh air beagan phuingean mun eadar-aghaidh Deque ann an Java:
- Chan eil am buileachadh sàbhailte ann an snàithlean oir chan eil sioncronadh taobh a-muigh ann.
- Chan eil Deque ann cuir taic ri concurrency le ioma-snàthainn.
- Cha leig Deque an sàs le arrays cleachdadh eileamaidean NULL.
- Tha cead aig arrays fàs a rèir nan riatanasan, le comas gun bhacadh agus taic airson ath-mheudachadh mar an dà fheart as cudromaiche.
A’ leantainn tha na diofar dhòighean a tha a’ faighinn taic bhon eadar-aghaidh Deque:
No. | Dòigh | Tuairisgeul |
---|---|---|
1 | cuir(eileamaid) | A’ cur eileamaid ris an earball. |
2 | cuir a’ chiad(eileamaid) | A’ cur eileamaid ris anceann/aghaidh. | 3 | addLast(element) | A' cur eileamaid ris an earball/cùl. |
4 | tairgse(eileamaid) | A' cur eileamaid ris an earball; a' tilleadh luach boolean a dh'fhaicinn an robh an cuir a-steach soirbheachail. |
5 | offerFirst(element) | A' cur eileamaid ris a' cheann; a' tilleadh luach boolean a sheallas an robh an cuir a-steach soirbheachail. |
6 | offerLast(element) | A' cur eileamaid ris an earball; a' tilleadh luach boolean a dh'fhaicinn an robh an cur a-steach soirbheachail. |
7 | iterator() | Tilleadh iterator airson an deque. |
8 | Iterator a’ teàrnadh() | Tilleadh iterator aig a bheil an t-òrdugh cùil airson an deque seo. |
9 | put(element) | A' cur eileamaid ri ceann na deque. |
10 | pop(element) | Thoir air falbh eileamaid o cheann na deque is tillidh e e. |
11 | air falbhFirst() | Thoir air falbh an eileamaid aig ceann an deic. |
12 | air falbhLast() | Thoir air falbh an eileamaid aig earball an deic. |
13 | taghaidh() | A’ faighinn air ais agus a’ toirt air falbh a’ chiad eileamaid den deic (air a riochdachadh le ceann na deque); a' tilleadh NULL ma tha an deque falamh. |
14 | pollFirst() | A' lorg 's a' toirt air falbh a' chiad eileamaid dhen deque seo; air ais null ma tha an deque seofalamh. |
taghaidhLast() | A' lorg 's a' toirt air falbh an eileamaid mu dheireadh dhen t-seasg seo; tillidh tu null ma tha an deque seo falamh. | |
16 | peek() | A’ faighinn air ais ceann (a’ chiad eileamaid dhen deic) den chiudha a tha air a riochdachadh leis a' chleas so ; tilleadh null ma tha an deque seo falamh. An aire: Chan toir an gnìomh seo air falbh an eileamaid. |
17 | peekFirst() | A’ faighinn air ais a’ chiad eileamaid den t-seagh seo; tilleadh null ma tha an deque seo falamh. An aire: Chan toir an gnìomh seo air falbh an eileamaid. |
18 | peekLast() | Tillidh seo an eileamaid mu dheireadh dhen deque seo air ais, no tillidh e null ma tha an deque seo falamh. An aire: Cha toir an t-obrachadh seo air falbh an eileamaid seo. |
Tha an gnìomh Java a leanas a’ sealltainn nan diofar obrachaidhean air an deach beachdachadh gu h-àrd.
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); } }
Toradh:
An deque : [11, 7, 3, 1, 5, 9, 13]
Iterator Coitcheann
11 7 3 1 5 9 13
Iterator Reverse
13 9 5 1 3 7 1
Peek 11
Às deidh na h-amhairc: [11, 7, 3, 1, 5, 9, 13]
Pop 11
An dèidh pop: [7, 3, 1, 5, 9, 13]
Anns an eileamaid 3?: fìor
Deque às dèidh toirt air falbh a' chiad agus na h-eileamaidean mu dheireadh: [3, 1, 5, 9]
Anns a’ phrògram gu h-àrd, tha sinn air an eadar-aghaidh Deque de Java a chleachdadh agus mhìnich sinn sreath de eileamaidean slàn-shlàn. An uairsin rinn sinn diofar obrachaidhean air an deque seo agus cuir a-mach toraidhean nan gnìomhachd sinair a thaisbeanadh.
Tagraidhean
Faodar deque a chleachdadh ann an cuid de na h-aplacaidean a leanas.
#1) Algorithm Clàraidh: Bidh algorithm clàraidh, “algorithm clàraidh A-steal” a’ buileachadh clàr-obrach airson diofar phròiseasan anns an t-siostam ioma-phròiseis. Bidh am buileachadh seo a' cleachdadh deque agus gheibh am pròiseasar a' chiad eileamaid on deque airson a chur gu bàs.
#2) Cuir dheth Liosta Ghnìomhan: Ann am prògraman bathar-bog, tha iomadh gnìomh againn. Tha aon dhiubh “cuir às dha”. Nuair a tha sinn air gnìomh neo-dhèanamh iomadh uair, tha na gnìomhan sin uile air an stòradh ann an liosta. Tha an liosta seo air a chumail mar dheic gus an urrainn dhuinn inntrigidhean a chur ris/a thoirt air falbh o cheann sam bith.
#3) Thoir air falbh na h-inntrigidhean às dèidh beagan ùine: Ùraich na h-aplacaidean Bidh na h-aplacaidean sin a’ toirt air falbh na h-inntrigidhean às deidh beagan ùine agus cuideachd cuir a-steach inntrigidhean ùra. Tha seo air a dhèanamh le bhith a’ cleachdadh deic.
Co-dhùnadh
’S e ciudha dà-thaobhach a th’ ann an Deque a leigeas leinn eileamaidean a chur ris/a thoirt air falbh bhon dà cheann i.e. aghaidh is cùlaibh, den chiudha. Faodar deque a chuir an gnìomh le bhith a’ cleachdadh arrays no liostaichean ceangailte. Ach, tha clas Leabharlann Teamplaid Coitcheann (STL) againn cuideachd a chuireas an gnìomh diofar obrachaidhean an Deque.
Ann an Java, tha eadar-aghaidh Deque againn a gheibhear bhon eadar-aghaidh ciudha gus Deque a chuir an gnìomh. A bharrachd air gnìomhachd àbhaisteach bunaiteach an Deque, tha an eadar-aghaidh seo a’ toirt taic do ghrunnobrachaidhean eile a ghabhas dèanamh air Deque.
Bithear a’ cleachdadh deque sa chumantas airson tagraidhean a dh’ fheumas eileamaidean a chur ris/a thoirt air falbh bhon dà cheann. Tha e cuideachd air a chleachdadh sa mhòr-chuid ann an clàradh phròiseasan ann an siostaman ioma-phròiseasar.
Thoir sùil air an t-sreath trèanaidh C++ coileanta