Di antara stack dan queue, struktur data yang lebih tepat digunakan untuk menyimpan operasi-operasi pengolahan dokumen terkait dengan fitur Undo dan Redo, adalah STACK.
Secara singkat, alasannya adalah karena data (dalam hal ini langkah / tindakan) yang diproses oleh kedua operasi tersebut (undo dan redo) sama-sama merupakan data (langkah / tindakan) terakhir pada himpunan data masing-masing, sehingga prinsip dasar yang tepat digunakan adalah LIFO (Last In First Out), artinya elemen yang terakhir masuk adalah elemen yang pertama dikeluarkan atau diproses.
Pembahasan
Deskripsi persoalan pada pertanyaan di atas sudah sangat jelas mengulas fitur Undo dan Redo yang terdapat pada aplikasi pengolah dokumen.
- Operasi Undo akan membatalkan langkah/ tindakan terakhir yang pengguna lakukan.
- Operasi Redo digunakan untuk mengulang kembali operasi yang baru saja dibatalkan dengan sebuah Undo.
Konsekuensinya:
- Jika pengguna sudah melakukan beberapa kali operasi Undo, maka redo mengulang kembali langkah / tindakan terakhir yang di-undo.
- Sebaliknya, jika pengguna sudah melakukan beberapa kali operasi Redo, maka undo membatalkan langkah / tindakan terakhir yang di-redo.
- Operasi Undo hanya bisa dilakukan atau memiliki efek terhadap dokumen jika sudah ada langkah / tindakan yang dilakukan oleh pengguna, atau sudah ada langkah / tindakan yang di-redo oleh pengguna.
- Operasi Redo hanya bisa dilakukan atau memiliki efek terhadap dokumen jika sudah ada langkah / tindakan yang di-undo oleh pengguna.
Jadi, untuk kedua operasi tersebut, data (langkah / tindakan) yang diproses adalah data terakhir yang masuk ke dalam himpunan data masing-masing.
Berdasarkan hal tersebut, struktur data yang tepat digunakan adalah stack (tumpukan).
Agar lebih jelas, kita telusuri saja sesuai persoalan yang diulas pada pertanyaan. Untuk fitur Undo-Redo, aplikasi memerlukan setidaknya 2 himpunan data, yang dalam hal ini bertipe data stack. Jadi, terdapat stack Undo dan stack Redo. Setiap langkah yang dilakukan oleh Budi langsung dimasukkan (di-push) ke dalam stack Undo.
Penelusuran berikut ini hanya bersifat mendasar saja. Implementasi sesungguhnya pada aplikasi bersifat lebih kompleks, karena harus ada struktur data lain yang menyimpan "konten" dari setiap langkah / tindakan yang dilakukan pengguna.
5 langkah awal yang dilakukan Budi adalah:
- Budi membuka dokumen A
- Budi menambahkan judul pada dokumen A
- Budi menulis sebuah paragraf pada dokumen A
- Budi menambahkan sebuah tabel pada dokumen A
- Budi menyisipkan sebuah gambar pada dokumen A
(nomor urut langkah dapat dianggap sebagai ID dari langkah)
Yang dilakukan oleh aplikasi pada stack Undo sesuai urutan langkah di atas adalah:
- push(UNDO, 1)
- push(UNDO, 2)
- push(UNDO, 3)
- push(UNDO, 4)
- push(UNDO, 5)
Kondisi stack saat ini:
[tex]\begin{aligned}\begin{array}{r|c|}\tt top\to&\tt5\\&\tt4\\&\tt3\\&\tt2\\&\tt1\\&\!\!\underline{\overline{\tt\,UNDO\,}}\!\!\\\end{array}\quad\begin{array}{|c|l}\tt[kosong]\\\!\!\underline{\overline{\tt\quad\, REDO\quad\,}}\!\!\end{array}\end{aligned}[/tex]
Kemudian, Budi menekan tombol Undo.
Aplikasi akan membatalkan langkah 5, yaitu penyisipan sebuah gambar, dan meng-update stack Undo dan Redo.
- push(REDO, UNDO.top)⇒ memasukkan elemen teratas (top) dari stack UNDO ke dalam stack REDO
- pop(UNDO)⇒ mengeluarkan elemen teratas (top) dari stack UNDO.
Kondisi stack saat ini:
[tex]\begin{aligned}\begin{array}{r|c|}\tt top\to&\tt4\\&\tt3\\&\tt2\\&\tt1\\&\!\!\underline{\overline{\tt\,UNDO\,}}\!\!\\\end{array}\quad\begin{array}{|c|l}\tt 5&\leftarrow\tt top\\\!\!\underline{\overline{\tt\,REDO\,}}\!\!\end{array}\end{aligned}[/tex]
Lalu, Budi menekan tombol Undo lagi.
Aplikasi akan membatalkan langkah 4, yaitu penambahan sebuah tabel, dan meng-update stack Undo dan Redo.
- push(REDO, UNDO.top)
- pop(UNDO)
Kondisi stack saat ini:
[tex]\begin{aligned}\begin{array}{r|c|}\tt top\to&\tt3\\&\tt2\\&\tt1\\&\!\!\underline{\overline{\tt\,UNDO\,}}\!\!\\\end{array}\quad\begin{array}{|c|l}\tt4&\leftarrow\tt top\\\tt5\\\!\!\underline{\overline{\tt\,REDO\,}}\!\!\end{array}\end{aligned}[/tex]
Setelah itu, Budi menekan tombol Redo.
Aplikasi akan mengulangi langkah 4 dengan mengambil kembali "konten" dari langkah 4, yaitu tabel yang tadi sudah ditambahkan (yang sudah tersimpan di memori dengan struktur data tertentu), dan meng-update stack Undo dan Redo.
- push(UNDO, REDO.top)⇒ memasukkan elemen teratas (top) dari stack REDO0 ke dalam stack UNDO
- pop(REDO)
Kondisi stack saat ini:
[tex]\begin{aligned}\begin{array}{r|c|}\tt top\to&\tt4\\&\tt3\\&\tt2\\&\tt1\\&\!\!\underline{\overline{\tt\,UNDO\,}}\!\!\\\end{array}\quad\begin{array}{|c|l}\tt 5&\leftarrow\tt top\\\!\!\underline{\overline{\tt\,REDO\,}}\!\!\end{array}\end{aligned}[/tex]
Dan seterusnya.