Selasa, 27 Februari 2018

Link List Implementation I-Roland Harry Tanuwijaya-2101635050

Nama saya Roland, Saya binusian 21 pada tgl 27-02-2018 adalah mengenal lebih dalam mengenai Linked List  yaitu Linked list implementation, Pengenalan Linked list telah dibahas pada sesi sebelumnya

Single Linkedlist adalah jenis daftar tertaut yang paling sederhana di mana setiap node berisi data yang sama dan pointer ke simpul berikutnya dari tipe data yang sama.

Sedangkan Double Linkedlist adalah Sama seperti dalam satu linked list, pertama kita harus mengalokasikan simpul baru dan tetapkan nilainya ke sana, lalu kita hubungkan node dengan linked list yang ada.
Single Linkedlist---->Insert
Untuk menyisipkan nilai baru, pertama kita harus mengalokasikan node baru secara dinamis dan memberikan nilai padanya dan kemudian menghubungkannya dengan linked list yang ada.

Seharusnya kita ingin menambahkan simpul baru di depan kepala.

struct tnode * node =
(struct tnode *) malloc (sizeof (struct tnode));
node-> nilai = x;
node-> next = head;

kepala = simpul;

Single Linkedlist---->Delete
Untuk menghapus sebuah nilai, pertama kita harus mencari lokasi
node yang menyimpan nilai yang ingin kita hapus, keluarkan,
dan hubungkan sisa linked list.

Seharusnya nilai yang ingin kita hapus adalah x dan
dengan asumsi x ada dalam linked list dan unik.

Ada dua kondisi yang harus kita perhatikan:

Jika x berada dalam head node atau x tidak berada dalam head node.

-Polinomial Representation
Polinomial diberikan sebagai 6x^3 + 9x^2 +7x+ 1
Setiap istilah individu dalam polinom terdiri dari dua bagian, koefisien dan kekuatan
Di sini, 6, 9, 7, dan 1 adalah koefisien dari persyaratan yang masing-masing memiliki 3, 2, 1, dan 0 sebagai kekuatan masing-masing.

Setiap istilah polinomial dapat direpresentasikan sebagai simpul dari linked list.


-Circular Single Linked List
Secara sirkuler, node terakhir berisi pointer ke node pertama
Kita bisa memiliki daftar terkait melingkar dan juga daftar ganda yang saling terkait.

Tidak ada penyimpanan nilai NULL dalam daftar

-Double Linkedlist --->Insert
Sama seperti dalam satu linked list, pertama kita harus mengalokasikan
simpul baru dan tetapkan nilainya ke sana, lalu kita
hubungkan node dengan linked list yang ada.

Seharusnya kita ingin menambahkan simpul baru di belakang ekor.

struct tnode * node =
(struct tnode *) malloc (sizeof (struct tnode));
node-> nilai = x;
node-> next = NULL;
node-> prev = ekor;
tail-> next = node;

ekor = simpul;

Seharusnya kita ingin memasukkan simpul baru dalam posisi tertentu (apapun
lokasi antara kepala dan ekor)

struct tnode * a = ??;
struct tnode * b = ??;
// node baru akan dimasukkan antara a dan b
struct tnode * node =
(struct tnode *) malloc (sizeof (struct tnode));
node-> nilai = x;
node-> next = b;
node-> prev = a;
a-> next = node;

b-> prev = simpul;

Double Linkedlist ---->Delete
Ada 4 kondisi yang harus kita perhatikan saat menghapus:
Node yang akan dihapus adalah satu-satunya simpul dalam linked list.
Simpul yang akan dihapus adalah kepala.
Simpul yang akan dihapus adalah ekor.
Simpul yang akan dihapus bukan kepala atau ekor.

1. Jika simpul yang akan dihapus adalah satu-satunya simpul:
bebas (kepala);
kepala = NULL;

ekor = NULL;

2. Jika simpul yang akan dihapus adalah kepala:
kepala = kepala-> berikutnya;
bebas (kepala-> prev);
head-> prev = NULL;

3. Jika simpul yang akan dihapus adalah ekor:
ekor = ekor-> prev;
bebas (ekor-> berikutnya);
tail-> next = NULL;


Selasa, 20 Februari 2018

Data Structure & Linked List -2101635050-Roland Harry T

Nama saya Roland, Saya binusian 21 pada tgl 20-02-2018 adalah pengenalan terhadap structure data , dimulai dari materi mengenai
-Array
-Pointer
-Data Structure
-Abstract Data Type

Array
Array adalah sekumpulan data yang sejenis dan dijadikan 1 buah data agar lebih mudah saat pendeklarasian karena tidak membutuhkan banyak nama variabel dan array dimulai dari indeks yang ke 0.
Syntax untuk mendeklarasikan Array di C adalah Type data-name-jumlah data contoh = int angka [20];
untuk memasukkan angka dapat dilakukan disaat pendeklarasian atau ditengah2 contoh = int angka[20] = {5,2,3,4,5,};

Array dapat dibuat dengan banyak dimensi yaitu 1 dimensi yang hanya terdiri dari baris atau 2 dimensi yang terdiri dari baris dan kolom/field dan property seperti pada tabel atau multi dimensi yang terdiri dari banyak dimensi.

Pengoperasian Array ,
Ada sejumlah operasi yang bisa dilakukan pada array hampir semuanya dapat dilakukkan pada data:
-Traversal
-Insertion
-Searching
-Deletion
-Merging
-Sorting

Pointer 
Pointer adalah variabel yang menunjuk alamat variabel lainnya.
Ada 2  tanda penting pada penulisan pointer yaitu * untuk operator deferencing dan & untuk menunjukkan suatu alamat

contoh pointer =
int x;
int *p;
*p= &x;
*p=7;
printf("%d", x);
maka yang di print nilainya adalah 7

Type of Data structure
Beberapa contoh umum dari struktur data meliputi:
-Arrays
-Linked lists= seperti mengikat suatu data dengan yang lainnya
-Queues= seperti mengantri di Atm yaitu First In First out atau Last in Last out
-Stacks= seperti mengambil shuttlekok di bulutangkis yaitu First in Last out atau Last in First out
-Binary trees =Seperti dalam pelajaran Matematika Diskrit mengenai graph Teory
-Hash tables

Abstract Data Type
Abstract Data Type (ADT) adalah tipe data yang disusun sedemikian rupa sehingga spesifikasi objek dan spesifikasi operasi pada objek dipisahkan dari representasi objek dan pelaksanaan operasi.

Pertanyaan dari Dosen Pengajar yang harus dicari :

1.       Berapa Banyak Dimensi dan Maksimum dari Array ?

2.       Perbedaan DoublePointer dengan Single Pointer? Dan berapa maksimum dimensi nya??

3.       Kekurangan dari array ialah?

4.       Perbedaan queues dan stacks ialah?



Jawab :

1.Banyak Dimensi dan Maksimum dari Array ialah :
Array dapat dijadikan banyak dimensi ( disebut juga multi dimensi) maka array tidak memiliki batasan maksimum nya .
2 Perbedaan dari single pointer dan double pointer adalah jika ada satu pointer yang hilang di double pointer maka suatu data tidak akan masuk nilainya/ jika bertahap maka tahapnya berhenti di saat pointer selanjutnya hilang. Jika di single pointer mengurangi kejadian seperti ini.
3.Kekurangan dari array ialah jika ada suatu array yang kosong maka akan membuang memory. Dan juga jika kita tidak tau berapa jumlah array yang akan dibutuhkan maka akan ada array yang kosong
4.Perbedaan queues dan stacks ialah , dalam queues , antrian pertama ialah antrian yang yang pertama masuk, dan pertama juga keluar (selesai). Namun pada stacks, (tumpukan ) yang pertama masuk akan menjadi yang terakhir keluar.Yang terakhir masuk akan menjadi yang pertama keluar.