- Double Ended Queue Classification
- ប្រតិបត្តិការ Deque មូលដ្ឋាន
- Deque Illustration
- ការអនុវត្ត Deque
- កម្មវិធី
- សេចក្តីសន្និដ្ឋាន
ការបង្រៀនស៊ីជម្រៅលើ Deque ឬ Double-ended Queue នៅក្នុង C++។ ការបង្រៀនពន្យល់ពីអ្វីទៅជា Deque, Basic Operations, C++ & ការអនុវត្ត និងកម្មវិធី Java៖
ជួរដែលបានបញ្ចប់ពីរដង ឬហៅថា "Deque" គឺជាកំណែទូទៅនៃ Queue។
ភាពខុសគ្នារវាង Queue និង Deque គឺថាវាមិនអនុវត្តតាម FIFO ទេ។ វិធីសាស្រ្ត (ដំបូងចូលដំបូង) ។ លក្ខណៈពិសេសទីពីររបស់ Deque គឺថាយើងអាចបញ្ចូល និងដកធាតុចេញពីផ្នែកខាងមុខ ឬផ្នែកខាងក្រោយ។
Double Ended Queue Classification
Deque can ត្រូវបានចាត់ថ្នាក់ដូចខាងក្រោម៖
ការដាក់កម្រិតការបញ្ចូល៖ នៅក្នុងការដាក់កម្រិត ការលុបអាចត្រូវបានធ្វើឡើងពីចុងទាំងពីរ ប៉ុន្តែការបញ្ចូលអាចត្រូវបានធ្វើតែនៅចុងខាងក្រោយនៃ ជួរ។
Output-restricted Deque៖ នៅក្នុងជួរដែលដាក់កំហិតទិន្នផល ការបញ្ចូលអាចត្រូវបានធ្វើឡើងពីចុងទាំងពីរ ប៉ុន្តែការលុបត្រូវបានធ្វើឡើងតែនៅចុងម្ខាង ពោលគឺផ្នែកខាងមុខនៃជួរ។
យើងក៏អាចអនុវត្តជង់ និងជួរដោយប្រើ deque ផងដែរ។
ប្រតិបត្តិការ Deque មូលដ្ឋាន
ខាងក្រោមគឺជាប្រតិបត្តិការមូលដ្ឋានដែលអាចត្រូវបានអនុវត្តនៅលើ deque ។
- បញ្ចូលផ្នែកខាងមុខ៖ បញ្ចូល ឬបន្ថែមធាតុនៅផ្នែកខាងមុខនៃឯកសារ។
- បញ្ចូលចុងក្រោយ៖ បញ្ចូល ឬបន្ថែមធាតុនៅ ផ្នែកខាងក្រោយនៃ deque។
- deleteFront: លុប ឬលុបធាតុចេញពីផ្នែកខាងមុខនៃជួរ។
- លុបចុងក្រោយ៖ លុប ឬលុបចេញ ធាតុពីខាងក្រោយជួរ។
- getFront: ទាញយកធាតុខាងមុខនៅក្នុង deque។
- getLast: ទាញយកធាតុចុងក្រោយនៅក្នុងជួរ។
- isEmpty: ពិនិត្យមើលថាតើ deque គឺទទេ។
- isFull: ពិនិត្យមើលថាតើ deque ពេញឬអត់។
Deque Illustration
Deque ទទេត្រូវបានតំណាងដូចខាងក្រោម៖
បន្ទាប់ យើងបញ្ចូលធាតុ 1 នៅផ្នែកខាងមុខ។
ឥឡូវនេះ យើងបញ្ចូលធាតុទី 3 នៅខាងក្រោយ។
បន្ទាប់ យើងបន្ថែមធាតុ 5 ទៅផ្នែកខាងមុខ ហើយនៅពេលបន្ថែមចំនុចខាងមុខទៅ 4.
បន្ទាប់មក យើងបញ្ចូលធាតុ 7 នៅខាងក្រោយ និង 9 នៅខាងមុខ។ deque នឹងមើលទៅដូចបង្ហាញខាងក្រោម។
បន្ទាប់ អនុញ្ញាតឱ្យយើងដកធាតុមួយចេញពីផ្នែកខាងមុខ។
ដូច្នេះ យើងឃើញថានៅពេលដែលធាតុត្រូវបានបញ្ចូលនៅផ្នែកខាងមុខ ទីតាំងខាងមុខត្រូវបានកាត់បន្ថយ ខណៈពេលដែលវាត្រូវបានបង្កើននៅពេលដែលធាតុមួយត្រូវបានដកចេញ។ សម្រាប់ផ្នែកខាងក្រោយ ទីតាំងត្រូវបានបង្កើនសម្រាប់ការបញ្ចូល និងបន្ថយសម្រាប់ការដកចេញ ។
ការអនុវត្ត Deque
ការអនុវត្ត C++ Deque
យើងអាចអនុវត្ត deque នៅក្នុង C ++ ដោយប្រើអារេ ក៏ដូចជាបញ្ជីភ្ជាប់។ ក្រៅពីនេះ បណ្ណាល័យគំរូស្តង់ដារ (STL) មានថ្នាក់ “deque” ដែលអនុវត្តមុខងារទាំងអស់សម្រាប់រចនាសម្ព័ន្ធទិន្នន័យនេះ។
ការអនុវត្តអារេនៃ deque ត្រូវបានផ្តល់ឱ្យខាងក្រោម។ ដោយសារវាជាជួរពីរជាន់ យើងបានប្រើអារេរាងជារង្វង់សម្រាប់ការអនុវត្ត។
#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; }
លទ្ធផល៖
បញ្ចូល ធាតុ 1 នៅផ្នែកខាងក្រោយ
បញ្ចូល ធាតុ 3 នៅផ្នែកខាងក្រោយ
ធាតុ ខាងក្រោយ នៃ deque 3
After deleterear, rear =
ការបញ្ចូលធាតុ 5 នៅចុងខាងមុខ
ធាតុខាងមុខ deque 5
After deletefront, front =
ការអនុវត្ត Java Deque
ចំណុចប្រទាក់ deque នៅក្នុង Java “java.util.Deque” គឺបានមកពីចំណុចប្រទាក់ “java.util.Queue” ។ Deque អាចត្រូវបានប្រើជាជួរ (ដំបូងចូលដំបូងចេញ) ឬជង់ (ចុងក្រោយចូលដំបូងចេញ) ។ ការអនុវត្តទាំងនេះដំណើរការលឿនជាងបញ្ជីដែលបានភ្ជាប់។
ដែលបានផ្តល់ឱ្យខាងក្រោមគឺជាឋានានុក្រមសម្រាប់ចំណុចប្រទាក់ Deque នៅក្នុង Java។
យើងត្រូវចងចាំចំណុចមួយចំនួនអំពីចំណុចប្រទាក់ Deque នៅក្នុង Java៖
- ការអនុវត្តមិនមានសុវត្ថិភាពដូចខ្សែទេ ដោយសារមិនមានការធ្វើសមកាលកម្មខាងក្រៅ។
- Deque មិនដំណើរការទេ។ គាំទ្រការស្របគ្នាដោយខ្សែស្រលាយច្រើន។
- ការអនុវត្តន៍របស់ Deque ដោយប្រើអារេមិនអនុញ្ញាតឱ្យប្រើធាតុ NULL ទេ។
- អារេត្រូវបានអនុញ្ញាតឱ្យរីកចម្រើនតាមតម្រូវការ ដោយមានសមត្ថភាពគ្មានការរឹតបន្តឹង និងការគាំទ្រអារេដែលអាចផ្លាស់ប្តូរទំហំបាន ជាមុខងារសំខាន់បំផុតពីរ។
ខាងក្រោមនេះគឺជាវិធីសាស្រ្តផ្សេងៗដែលគាំទ្រដោយចំណុចប្រទាក់ Deque៖
ទេ | វិធីសាស្រ្ត | ការពិពណ៌នា |
---|---|---|
1 | បន្ថែម(ធាតុ) | បន្ថែមធាតុមួយទៅកន្ទុយ។ |
2 | បន្ថែមដំបូង(ធាតុ) | បន្ថែមធាតុមួយទៅក្បាល/ខាងមុខ។ |
3 | បន្ថែមចុងក្រោយ(ធាតុ) | បន្ថែមធាតុទៅកន្ទុយ/ខាងក្រោយ។ |
4 | ការផ្តល់ជូន(ធាតុ) | បន្ថែមធាតុមួយទៅកន្ទុយ។ ត្រឡប់តម្លៃប៊ូលីន ដើម្បីបង្ហាញថាការបញ្ចូលបានជោគជ័យ។ |
5 | offerFirst(element) | បន្ថែមធាតុមួយទៅក្បាល។ ត្រឡប់តម្លៃប៊ូលីន ដើម្បីបង្ហាញថាការបញ្ចូលបានជោគជ័យ។ |
6 | offerLast(element) | បន្ថែមធាតុទៅកន្ទុយ។ ត្រឡប់តម្លៃប៊ូលីន ដើម្បីបង្ហាញថាការបញ្ចូលបានជោគជ័យឬអត់។ |
7 | iterator() | ត្រឡប់ iterator សម្រាប់ deque។ |
8 | descendingIterator() | ត្រឡប់ iterator ដែលមានលំដាប់បញ្ច្រាសសម្រាប់ deque នេះ។ |
9 | push(element) | បន្ថែមធាតុមួយទៅក្បាល deque។ |
10 | pop(element) | លុបធាតុមួយចេញពីក្បាល deque ហើយបញ្ជូនវាមកវិញ។ |
11 | removeFirst() | លុបធាតុនៅ ក្បាល deque។ |
12 | removeLast() | លុបធាតុនៅកន្ទុយ deque។ |
13 | ការស្ទង់មតិ() | ទាញយក និងលុបធាតុដំបូងនៃ deque (តំណាងដោយប្រធាន deque); ត្រឡប់ NULL ប្រសិនបើ deque ទទេ។ |
14 | pollFirst() | ទាញយក និងយកធាតុដំបូងនៃ deque នេះចេញ។ ត្រឡប់ null ប្រសិនបើ deque នេះគឺទទេ។ |
15 | pollLast() | ទាញយក និងលុបធាតុចុងក្រោយនៃ deque នេះចេញ។ ត្រឡប់ null ប្រសិនបើ deque នេះទទេ។ |
16 | peek() | ទាញក្បាល(ធាតុដំបូងនៃ deque) នៃជួរដែលតំណាង ដោយ deque នេះ; ត្រឡប់ null ប្រសិនបើ deque នេះទទេ។ ចំណាំ៖ ប្រតិបត្តិការនេះមិនដកធាតុចេញទេ។ |
17 | peekFirst() | ទាញយកធាតុដំបូងនៃ deque នេះ; ត្រឡប់ null ប្រសិនបើ deque នេះទទេ។ ចំណាំ៖ ប្រតិបត្តិការនេះមិនដកធាតុចេញទេ។ |
18 | peekLast() | ទាញយកធាតុចុងក្រោយនៃ deque នេះ ឬត្រឡប់ជា null ប្រសិនបើ deque នេះទទេ។ ចំណាំ៖ ប្រតិបត្តិការនេះមិនដកធាតុចេញទេ។ |
ការអនុវត្ត 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]
Standard Iterator
11 7 3 1 5 9 13
Reverse Iterator
13 9 5 1 3 7 1
Peek 11
បន្ទាប់ពីមើល៖ [11, 7, 3, 1, 5, 9, 13]
Pop 11
បន្ទាប់ពី pop ៖ [7, 3, 1, 5, 9, 13]
មានធាតុ 3?: true
Deque បន្ទាប់ពី លុប ធាតុទីមួយ និង ចុងក្រោយ ៖ [3, 1, 5, 9]
នៅក្នុងកម្មវិធីខាងលើ យើងបានប្រើចំណុចប្រទាក់ Deque នៃ Java ហើយយើងបានកំណត់ deque នៃចំនួនគត់។ បន្ទាប់មកយើងបានអនុវត្តប្រតិបត្តិការផ្សេងគ្នានៅលើ deque នេះនិងលទ្ធផលនៃប្រតិបត្តិការទាំងនេះគឺជាបានបង្ហាញ។
កម្មវិធី
Deque អាចត្រូវបានប្រើនៅក្នុងកម្មវិធីមួយចំនួនខាងក្រោម។
#1) ក្បួនដោះស្រាយកាលវិភាគ៖ ក្បួនដោះស្រាយកាលវិភាគ "A-steal scheduling algorithm" អនុវត្តការកំណត់ពេលភារកិច្ចសម្រាប់ processors ផ្សេងៗនៅក្នុងប្រព័ន្ធ multiprocessor។ ការអនុវត្តនេះប្រើ deque ហើយ processor ទទួលបានធាតុដំបូងពី deque សម្រាប់ការប្រតិបត្តិ។
#2) មិនធ្វើវិញនូវបញ្ជីសកម្មភាព៖ នៅក្នុងកម្មវិធី software យើងមានសកម្មភាពជាច្រើន។ មួយគឺ "មិនធ្វើវិញ" ។ នៅពេលដែលយើងអនុវត្តសកម្មភាពមិនធ្វើវិញច្រើនដង សកម្មភាពទាំងអស់នេះត្រូវបានរក្សាទុកក្នុងបញ្ជីមួយ។ បញ្ជីនេះត្រូវបានរក្សាទុកជាឯកសារដើម្បីឱ្យយើងអាចបន្ថែម/យកធាតុចេញពីចុងណាមួយបានយ៉ាងងាយស្រួល។
#3) លុបធាតុចេញបន្ទាប់ពីមួយរយៈពេលក្រោយ៖ កម្មវិធីផ្ទុកឡើងវិញ ធាតុនៅក្នុងបញ្ជីរបស់ពួកគេ ដូចជាកម្មវិធីដែលរាយបញ្ជីភាគហ៊ុនជាដើម។ កម្មវិធីទាំងនេះដកធាតុចេញបន្ទាប់ពីពេលខ្លះ ហើយបញ្ចូលធាតុថ្មីផងដែរ។ នេះត្រូវបានធ្វើដោយប្រើ deque។
សេចក្តីសន្និដ្ឋាន
Deque គឺជាជួរពីរដែលអនុញ្ញាតឱ្យយើងបន្ថែម/យកធាតុចេញពីចុងទាំងពីរ ពោលគឺផ្នែកខាងមុខ និងខាងក្រោយ នៃជួរ។ Deque អាចត្រូវបានអនុវត្តដោយប្រើអារេ ឬបញ្ជីដែលភ្ជាប់។ ទោះយ៉ាងណាក៏ដោយ យើងក៏មានថ្នាក់ Standard Template Library (STL) ដែលអនុវត្តប្រតិបត្តិការផ្សេងៗនៃ Deque ផងដែរ។
នៅក្នុង Java យើងមានចំណុចប្រទាក់ Deque ដែលត្រូវបានទទួលមរតកពីចំណុចប្រទាក់ជួរដើម្បីអនុវត្ត Deque ។ ក្រៅពីប្រតិបត្តិការស្តង់ដារមូលដ្ឋានរបស់ Deque ចំណុចប្រទាក់នេះគាំទ្រផ្សេងៗប្រតិបត្តិការផ្សេងទៀតដែលអាចត្រូវបានអនុវត្តនៅលើ Deque ។
Deque ជាទូទៅត្រូវបានប្រើសម្រាប់កម្មវិធីដែលត្រូវការបន្ថែម/យកធាតុចេញពីចុងទាំងពីរ។ វាត្រូវបានគេប្រើភាគច្រើនផងដែរនៅក្នុងការកំណត់កាលវិភាគនៃដំណើរការនៅក្នុងប្រព័ន្ធពហុដំណើរការ។
ពិនិត្យមើលស៊េរីបណ្តុះបណ្តាល C++ ពេញលេញ