tugas 1
#include
/* Program asli oleh Simon Tatham 2001.
* Simplikasi oleh Husni Thamrin 2011
*/
struct _simpul{
int data;
struct _simpul *next;
};
typedef struct _simpul simpul;
/*fungsi untuk membandingkan isi simpul*/
int cmp(simpul *a, simpul *b) {
return a->data - b->data;
}
/*Fungsi mergeSort
*Cara memanggil:
*list = mergeSort(mylist);
*/
simpul *mergeSort(simpul *list) {
simpul *p, *q, *e, *tail;
int insize, nmerges, psize, qsize, i;
/*Jila input hanya berisi NULL, nilai kembalian adalah NULL*/
if (!list) return NULL;
insize = 1;
while (1) {
p = list;
list = NULL;
tail = NULL;
nmerges = 0; /*hitungan jumlah merge yang dilakukan
di tiap iterasi */
while (p) {
nmerges++; /*masih ada proses merge */
/*bergerak sebanyak'insize' kali dari p */
q = p;
psize = 0;
for (i = 0;i< insize; i++) { psize++; q = q->next;
if(!q) break;
}
/*jika q sudah mencapai ujung list, terdapat dua list
* yang perlu di-merge */
qsize = insize;
/* sampai sini terdapat dua list;siap melakukan merge*/
while (psize > 0|| (qsize > 0 && q)) {
/*cek apakah elemen berikutnya harus dari p atau q*/
if (psize == 0){
/*jika p kosong ; e diambil dari q. */
e = q; q=q->next; qsize--;
} else if (qsize == 0|| !q) {
/* jika q kosong; e diambil dari p. */
e = p; p = p->next;psize--;
} else if (cmp(p,q) <= 0) { /*Elemen pertama p lebih kecil (atau sama); *e diambil dari p.*/ e = p; p = p->next; psize--;
} else {
/* Elemen pertama q lebih kecil; e diambil dari q. */
e = q; q = q->next; qsize--;
}
/* tambahan elemen berikutnya ke list hasil merge */
if (tail) {
tail->next = e;
} else {
list = e;
}
tail = e;
}
/* p telah melangkah sebanyak 'insize' ksli, q juga */
p = q;
}
tail->next = NULL;
/* Jika telah dilakukan satu merge, pekerjaan selesai.*/
if (nmerges <= 1)/* cek kemungkinan list kosong:nmerges==0*/ return list; /*Jika tidak, ulangi! merge list dua kali ukurannya*/ insize *=2; } } int main(void) { /*Konstruksi linked-list, array simpul yang disambung-sambung *catatan: cara konstruksi ini bukan prosedur standart, *sekedar utk contoh pada proses sortting*/ #define n 13 simpul k[n],*head,*p; int Data[n] = { 6 , 2 , 8 , 4 , 11 , 1 , 12 , 7 , 3 , 9 , 5 , 0 , 10 }; int j; for (j = 0;j
p = p-> next;
} while (p != NULL);
printf("\n\n");
head = mergeSort(head);/*memanggil fungsi sorting*/
/*Menampilkan isi linked list*/
printf("Setelah pengurutan:");
p = head;
do {
printf("%d\n", p->data);
p = p->next;
} while (p != NULL);
printf("\n\n");
return 0;
}
tugas 2
#include
/* Program asli oleh Simon Tatham 2001.
* Simplikasi oleh Husni Thamrin 2011
*/
struct _simpul{
float data;
struct _simpul *next;
};
typedef struct _simpul simpul;
/*fungsi untuk membandingkan isi simpul*/
int cmp(simpul *a, simpul *b) {
return (a->data) > (b->data);
}
/*Fungsi mergeSort
*Cara memanggil:
*list = mergeSort(mylist);
*/
simpul *mergeSort(simpul *list) {
simpul *p, *q, *e, *tail;
int insize, nmerges, psize, qsize, i;
/*Jila input hanya berisi NULL, nilai kembalian adalah NULL*/
if (!list) return NULL;
insize = 1;
while (1) {
p = list;
list = NULL;
tail = NULL;
nmerges = 0; /*hitungan jumlah merge yang dilakukan
di tiap iterasi */
while (p) {
nmerges++; /*masih ada proses merge */
/*bergerak sebanyak'insize' kali dari p */
q = p;
psize = 0;
for (i = 0;i< insize; i++) { psize++; q = q->next;
if(!q) break;
}
/*jika q sudah mencapai ujung list, terdapat dua list
* yang perlu di-merge */
qsize = insize;
/* sampai sini terdapat dua list;siap melakukan merge*/
while (psize > 0|| (qsize > 0 && q)) {
/*cek apakah elemen berikutnya harus dari p atau q*/
if (psize == 0){
/*jika p kosong ; e diambil dari q. */
e = q; q=q->next; qsize--;
} else if (qsize == 0|| !q) {
/* jika q kosong; e diambil dari p. */
e = p; p = p->next;psize--;
} else if (cmp(p,q) <= 0) { /*Elemen pertama p lebih kecil (atau sama); *e diambil dari p.*/ e = p; p = p->next; psize--;
} else {
/* Elemen pertama q lebih kecil; e diambil dari q. */
e = q; q = q->next; qsize--;
}
/* tambahan elemen berikutnya ke list hasil merge */
if (tail) {
tail->next = e;
} else {
list = e;
}
tail = e;
}
/* p telah melangkah sebanyak 'insize' ksli, q juga */
p = q;
}
tail->next = NULL;
/* Jika telah dilakukan satu merge, pekerjaan selesai.*/
if (nmerges <= 1)/* cek kemungkinan list kosong:nmerges==0*/ return list; /*Jika tidak, ulangi! merge list dua kali ukurannya*/ insize *=2; } } int main(void) { /*Konstruksi linked-list, array simpul yang disambung-sambung *catatan: cara konstruksi ini bukan prosedur standart, *sekedar utk contoh pada proses sortting*/ #define n 10 simpul k[n],*head,*p; float Data[n] = { 3.5 , 4.7 , 4.9 , 6.2 , 9.3 , 5.8 , 2.8 , 8.3 , 5.2 , 3.9 }; int j; for (j = 0;j
p = p-> next;
} while (p != NULL);
printf("\n\n");
head = mergeSort(head);/*memanggil fungsi sorting*/
/*Menampilkan isi linked list*/
printf("Setelah pengurutan:");
p = head;
do {
printf("%.2f\n", p->data);
p = p->next;
} while (p != NULL);
printf("\n\n");
return 0;
}
tugas 3
#include
/* Program asli oleh Simon Tatham 2001.
* Simplikasi oleh Husni Thamrin 2011
*/
struct _simpul{
float data;
struct _simpul *next;
};
typedef struct _simpul simpul;
/*fungsi untuk membandingkan isi simpul*/
int cmp(simpul *a, simpul *b) {
return (a->data) < (b->data);
}
/*Fungsi mergeSort
*Cara memanggil:
*list = mergeSort(mylist);
*/
simpul *mergeSort(simpul *list) {
simpul *p, *q, *e, *tail;
int insize, nmerges, psize, qsize, i;
/*Jila input hanya berisi NULL, nilai kembalian adalah NULL*/
if (!list) return NULL;
insize = 1;
while (1) {
p = list;
list = NULL;
tail = NULL;
nmerges = 0; /*hitungan jumlah merge yang dilakukan
di tiap iterasi */
while (p) {
nmerges++; /*masih ada proses merge */
/*bergerak sebanyak'insize' kali dari p */
q = p;
psize = 0;
for (i = 0;i< insize; i++) { psize++; q = q->next;
if(!q) break;
}
/*jika q sudah mencapai ujung list, terdapat dua list
* yang perlu di-merge */
qsize = insize;
/* sampai sini terdapat dua list;siap melakukan merge*/
while (psize > 0|| (qsize > 0 && q)) {
/*cek apakah elemen berikutnya harus dari p atau q*/
if (psize == 0){
/*jika p kosong ; e diambil dari q. */
e = q; q=q->next; qsize--;
} else if (qsize == 0|| !q) {
/* jika q kosong; e diambil dari p. */
e = p; p = p->next;psize--;
} else if (cmp(p,q) <= 0) { /*Elemen pertama p lebih kecil (atau sama); *e diambil dari p.*/ e = p; p = p->next; psize--;
} else {
/* Elemen pertama q lebih kecil; e diambil dari q. */
e = q; q = q->next; qsize--;
}
/* tambahan elemen berikutnya ke list hasil merge */
if (tail) {
tail->next = e;
} else {
list = e;
}
tail = e;
}
/* p telah melangkah sebanyak 'insize' ksli, q juga */
p = q;
}
tail->next = NULL;
/* Jika telah dilakukan satu merge, pekerjaan selesai.*/
if (nmerges <= 1)/* cek kemungkinan list kosong:nmerges==0*/ return list; /*Jika tidak, ulangi! merge list dua kali ukurannya*/ insize *=2; } } int main(void) { /*Konstruksi linked-list, array simpul yang disambung-sambung *catatan: cara konstruksi ini bukan prosedur standart, *sekedar utk contoh pada proses sortting*/ #define n 10 simpul k[n],*head,*p; float Data[n] = { 3.5 , 4.7 , 4.9 , 6.2 , 9.3 , 5.8 , 2.8 , 8.3 , 5.2 , 3.9 }; int j; for (j = 0;j
p = p-> next;
} while (p != NULL);
printf("\n\n");
head = mergeSort(head);/*memanggil fungsi sorting*/
/*Menampilkan isi linked list*/
printf("Setelah pengurutan:");
p = head;
do {
printf("%.2f\n", p->data);
p = p->next;
} while (p != NULL);
printf("\n\n");
return 0;
}
struktur data modul 7
by yannysolo pada 13.09 0 komentar
Langganan:
Postingan (Atom)