Skip to main content

App Linked List Store Management


Berikut ini adalah source code untuk manajemen barang jual beli yang sederhana.

Nama : Christopher Wibisono
NIM : 2301913822

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <string.h>

int total;

struct ll
{
int qty;
char nama[50];
int price;
struct ll *next;
struct ll *prev;
}*head = NULL, *tail = NULL, *curr;

void print()
{
curr = head;
if (curr == NULL)
printf("No Data!\n");
else
{
int i = 1;
while(curr != NULL)
{
printf("---------------------\n");
printf("Data %d : %s\n",i,curr->nama);
printf("Quantity %d : %d\n",i,curr->qty);
printf("Price %d : %d\n",i,curr->price);
curr = curr->next;
i++;
}
}
}

void push()
{
curr = (struct ll*)malloc(sizeof(struct ll));
printf("Input Name : ");
scanf("%[^\n]",curr->nama);
printf("Input Quantity : ");
scanf("%d",&curr->qty);
getchar();
curr->price = rand() % 100 + 1;
printf("Price Generated : $%d\n",curr->price);
curr->next = curr->prev = NULL;
if (head == NULL)
{
head = tail = curr;
}
else if (strcmp(curr->nama,head->nama) < 0)
{
curr->next = head;
head->prev = curr;
head = curr;
}
else if (strcmp(curr->nama,tail->nama) > 0)
{
curr->prev = tail;
tail->next = curr;
tail = curr;
}
else
{
struct ll *temp = head;
while (strcmp(curr->nama,temp->next->nama) > 0)
{
temp = temp->next;
}
curr->next = temp->next;
temp->next->prev = curr->prev;
temp->next = curr;
}
}

void update()
{
print();
char nk[50];
if(head != NULL)
{
struct ll *temp = head;
strcpy(nk,"NULL");
printf("Input data to be updated (name) : ");
scanf("%[^\n]",nk);
getchar();
while(temp != NULL && strcmp(nk,temp->nama) != 0)
{
temp = temp->next;
}
if(temp == NULL)
{
printf("Data %s not found!\n",nk);
}
else
{
printf("Update quantity : ");
scanf("%d",&temp->qty);
getchar();
}
}
}

int q;

void kurang(int h)
{
q = 0;
do
{
printf("Input Quantity to be checked out : ");
scanf("%d",&q);
getchar();
if(q > h)
printf("Quantity in storage less than %d\n",q);
else if(q == 0)
printf("Cannot checkout 0 items\n");
} while (q > h || q == 0);
}

void cekout()
{
if(head == NULL)
{
printf("No Data!\n");
}
else
{
char nx[50];
int no = 0;
while(strcmp(nx,"0") != 0)
{
strcpy(nx,"NULL");
print();
if (head == NULL)
break;
printf ("Input 0 to end checkout\n");
printf ("Input data to checkout : ");
scanf("%[^\n]",nx);
getchar();
if (strcmp(nx,"0") == 0)
break;
int qx = 0;
if (head == tail && strcmp(nx,head->nama) == 0)
{
qx = head->qty;
kurang(qx);
head->qty-=q;
total+=head->price*q;
if(head->qty == 0)
{
free(head);
head = tail = NULL;
}
}
else if (strcmp(nx,head->nama) == 0)
{
curr = head;
qx = curr->qty;
kurang(qx);
total+=curr->price*q;
curr->qty-=q;
if(curr->qty == 0)
{
head = head->next;
free(curr);
head->prev = NULL;
}
else
{
head = curr;
}
}
else if (strcmp(nx,tail->nama) == 0)
{
curr = tail;
qx = curr->qty;
kurang(qx);
total+=curr->price*q;
curr->qty-=q;
if(curr->qty == 0)
{
tail = tail->prev;
free(curr);
tail->next = NULL;
}
else
{
tail = curr;
}
}
else
{
curr = head;
ll *temp;
while(curr != NULL && strcmp(curr->nama,nx) != 0)
{
temp = curr;
curr = curr->next;
}
if (curr == NULL)
{
printf("Data : %s not found!\n",nx);
}
else
{
qx = curr->qty;
kurang(qx);
total+=curr->price*q;
curr->qty-=q;
if(curr->qty == 0)
{
temp->next = curr->next;
curr->next->prev = temp;
free(curr);
}
}
}
}
printf("Total Price : %d\n",total);
printf("Checkout Price : FREE\n");
printf("kindness is free\n");
}
}

void del()
{
if (head == NULL)
{
printf("No Data!\n");
}
else
{
print();
char x[50];
printf("Input data to be deleted : ");
scanf("%[^\n]",x);
getchar();
if (head == tail && strcmp(x,head->nama) == 0)
{
free(head);
head = tail = NULL;
}
else if (strcmp(x,head->nama) == 0)
{
curr = head;
head = head->next;
free(curr);
head->prev = NULL;
}
else if (strcmp(x,tail->nama) == 0)
{
curr = tail;
tail = tail->prev;
free(curr);
tail->next = NULL;
}
else
{
curr = head;
ll *temp;
while(curr != NULL && strcmp(x,curr->nama) != 0)
{
temp = curr;
curr = curr->next;
}
if (curr == NULL)
{
printf("Data : %s not found!\n",x);
}
else
{
temp->next = curr->next;
curr->next->prev = temp;
free(curr);
}
}
}
}

int main()
{
int ch;
do
{
ch = -1;
printf ("Menu :\n");
printf ("0. Exit\n");
printf ("1. Add Data\n");
printf ("2. Update Data\n");
printf ("3. Checkout Data\n");
printf ("4. View Data\n");
printf ("5. Delete Data\n");
printf ("Your Choice : ");
scanf("%d",&ch);
getchar();
if (ch == 1)
{
push();
}
else if (ch == 2)
{
update();
}
else if (ch == 3)
{
total = 0;
cekout();
}
else if (ch == 4)
{
printf ("List of data :\n");
print();
}
else if (ch == 5)
{
del();
}
printf ("Process Completed!\nPress enter to continue...");
getchar();
system ("cls");
}
while(ch != 0);
printf("Christopher Wibisono - 2301913822\n");
return 0;
}
Jika ingin mencoba - coba, berikut saya cantumkan link untuk download file .cpp dari source code diatas.

https://drive.google.com/open?id=1UOEhjK7BOn4Io_3OZ5Q6hpn1tPRPFH7l

Terima kasih atas kunjungannya :3

Comments

Popular posts from this blog

AVL Tree

AVL Tree adalah lanjutan dari Binary Search Tree . Dengan AVL Tree , Binary Search Tree yang tingginya berat sebelah akan dibuat menjadi rata dengan mengubah posisi dari node yang membuat tree tidak seimbang. Pengubahan posisi tersebut dilakukan dengan cara rotating , dimana node yang menjadi akar masalah dalam tree tersebut akan dipindahkan menjadi node yang berada diatas nya dan node yang berada pada atasnya akan berubah tempat mengikuti dengan aturan Binary Search Tree . Rotating terbagi menjadi dua, yaitu Single Rotate dan Double Rotate . Seperti namanya, Single Rotation merupakan Rotasi yang dilakukan sekali saja. Rotasi ini hanya dilakukan sekali saja, dengan menemukan node yang membuat tree tersebut tidak seimbang, lalu menggantikan node tersebut dengan node yang berada di bawahnya serta memindah node itu sendiri untuk menyeimbangkan tree tersebut. Node 30 menempati node 25 dan node 25 menjadi leaf kiri node 30 untuk menyeimbangkan tree ....

Rangkuman 2

Nama: Christopher Wibisono NIM: 2301913822 Nama Dosen: CB01 (Kelas Besar) : Henry Chong(D4460) & Ferdinand Ariandy Luwinda (D4522) LM01 (Kelas Kecil) : Alexander (D5319) Pada blog kali ini, kita akan mereview apa saja yang sudah dipelajari selama akhir semester 2 ini. AVL Tree  adalah lanjutan dari  Binary Search Tree . Dengan  AVL Tree ,  Binary Search Tree  yang tingginya berat sebelah akan dibuat menjadi rata dengan mengubah posisi dari  node  yang membuat  tree  tidak seimbang. Pengubahan posisi tersebut dilakukan dengan cara  rotating , dimana  node  yang menjadi akar masalah dalam  tree  tersebut akan dipindahkan menjadi node yang berada diatas nya dan node yang berada pada atasnya akan berubah tempat mengikuti dengan aturan  Binary Search Tree . Rotating  terbagi menjadi dua, yaitu  Single Rotate  dan  Double Rotate . Seperti namanya,  Single Rotation  ...

Linked List

Pada materi kali ini, kita membahas tentang Linked List dalam bahasa pemrograman C. Untuk kali ini kita akan fokus terhadap beberapa jenis Linked List yang lebih dalam termasuk : 1.         Circular Singly Linked List 2.       Doubly Linked List 3.       Circular Doubly Linked List Linked List sendiri adalah struktur data yang menyimpan sebuah data serta sebuah referensi untuk menunjukkan data selanjutnya dalam urutan tertentu. Circular Single Linked List Dalam Circular Single Linked List, untuk mengakses bagian mana pun, kita perlu melewati data pertama yang ada dalam urutan. Jika dalam pengecekan kita berada dalam tengah urutan, maka tidak mungkin kita dapat mengakses data yang berada sebelum bagian di mana kita berada. Nilai NULL dalam Circular Single Linked List tidak disimpan dalam urutan data. Berikut ini gambar untuk memasukkan nilai awal dalam Circular Single Linked List , Sama halnya sep...