Ngăn xếp bằng danh sách liên kết

Đầu tiên, các bạn mở Code::Blocks 10.05 lên, tạo một file mới tên là thuvien.cpp

Sau đó, gõ nội dung:

#include <stdio.h>
#include <malloc.h>

typedef
int ElementType;
typedef struct
Node{
ElementType Element;
Node* Next;
};

typedef
Node* Position;
typedef
Position List;
void
MakeNullList(List &L){
L=(Node*)malloc(sizeof(Node));
L->Next=NULL;
}


int
EmptyList(List L){
return
L->Next==NULL;
}


void
InsertList(ElementType X, Position P, List L){
Position T = (Node*)malloc(sizeof(Node));
T->Element = X;
T->Next = P->Next;
P->Next = T;
}


void
DeleteList(Position P,List &L){
if
(!EmptyList(L)){
Position T = P->Next;
P->Next = T->Next;
free(T);
}
}

void
PrintList(List L){
while
(L->Next!=NULL){
printf("%d ",L->Next->Element);
L=L->Next;
}
}

Tiếp theo, tạo một file mới tên là nganxep.cpp, lưu file này cùng thư mục với file thuvien.cpp và gõ nội dung như sau:

#include "thuvien.cpp"

typedef
List Stack;
void
MakeNullStack(Stack &S){
MakeNullList(S);
}

void
Push(ElementType X, Stack &S){
InsertList(X,S,S);
}

void
Pop(Stack &S){
DeleteList(S,S);
}

ElementType Top(Stack S){
return
S->Next->Element;
}

int
EmptyStack(Stack S){
return
EmptyList(S);
}

int
main(){
Stack S;
MakeNullStack(S);
printf("Moi ban nhap so thap phan = ");
int
n;
scanf("%d",&n);
printf("So %d o he nhi phan la: ",n);
while
(n>0){
Push(n%2,S);
n = n/2;
}

while
(!EmptyStack(S)){
printf("%d",Top(S));
Pop(S);
}


printf("\n\nMoi nhap so n = ");
scanf("%d",&n);
for
(int i=1;i<=n;i++){
int
t = i;
printf("%d = ",t);
while
(t>0){
Push(t%2,S);
t = t/2;
}

while
(!EmptyStack(S)){
printf("%d",Top(S));
Pop(S);
}

printf("\n");
}

return
0;
}

Video: trên lớp mình đã giải thích ý nghĩa của các lệnh rồi nên trong video mình không giải thích cụ thể lại, các bạn xem video này để biết được đoạn code nào nên đánh trước, đánh sau, chứ không nên đánh code theo kiểu nhìn bài mẫu rồi code từ A->Z vào.



 
Mã nguồn: dành cho các bạn đánh nhưng không chạy. TẢI VỀ

Bài liên quan

Bài liên quan