Ciudha le crìoch dùbailte (deque) Ann an C ++ le eisimpleirean

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.

#include using 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:

24> 15
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

Sgrolaich gu barr