Công cụ bảo vệ mã nguồn .NET mạnh nhất, không thể unpack, miễn phí cho các khách hàng đầu tiên đăng ký.
Từ 1 tới 10 trên tổng số 10 kết quả

Đề tài: STACK & QUEUE Dùng Mảng 1 Chiều !

Threaded View

  1. #1
    Ngày gia nhập
    10 2006
    Nơi ở
    In Your Bugs
    Bài viết
    823

    Mặc định STACK & QUEUE Dùng Mảng 1 Chiều !

    Bài viết này của kidkid không biết có được gọi là tut không nữa ? Lần đầu tiên viết tut về C/C++ , do đó có chi mọi người cứ góp ý .
    Hiện nay đối với phần lớn SV năm I như kidkid thì phần lớn anh em chưa được học Danh Sách Liên Kết (DSLK) do đó mặc dù vẫn hay nghe đến những tên gọi rất quen thuộc như Stack (Ngăn Xếp ) và Queue (Hàm đợi ) vẫn chưa thể cài đặt được nó .
    Tất nhiên trong các mục ebook thì vẫn nói rất nhiều về vấn đề này , nhưng phần lớn vẫn dành sự ưu ái cho những ai đã biết qua CTDL , hôm nay kidkid viết 1 bài hoàn toàn mới về cách cài đặt Stack và Queue sử dụng những kiến thức đúng với tên gọi của “Box C/C++ cơ bản “ .

    1. Cài đặt Stack sử dụng C và mảng một chiều :

    Đầu tiên kidkid xin được nói sơ qua về Stack mặc dù các bạn ít nhiều đã biết về nó . Stack là một cấu trúc có nhiều nút như một list vậy , tuy nhiên chúng ta chỉ có thể thêm vào hoặc lấy ra 1 nút tại đỉnh của nó ! Kidkid lấy ví dụ thế này , khi chúng ta nạp đạn ,viên nạp đạn cuối cùng sẽ là viên được bắn trước tiên còn viên nạp đầu tiên sẽ được bắn cuối cùng như vậy chúng ta sẽ tóm là 1 câu là Vào Trước Ra Sau hay Last In First Out . ( Xem Hình )



    Bây giờ chúng ta xem buồng đạn này như 1 stack . mỗi viên đạn nạp vào là 1 nút .
    Như vậy để biết tổng số viên đạn có thể nạp vào chúng ta sẽ có một biến tên là MAX (ở đây MAX=6) , tốt rồi bây giờ để biết số đạn hiện có chúng ta sẽ dùng một biến TOP . Mỗi lần nạp đạn ta phải nạp từng viên một do đó để nạp một viên chúng ta phải biết được là buồng đạn này đầy chưa ! Có nghĩa là nếu TOP =MAX thì buồng đạn đầy và TOP = 0 thì buồng đạn rỗng (nhưng vì đặc điểm riêng của mảng 1 chiều với chỉ số từ 0 đến n-1 nên stack đầy khi TOP +1 = MAX , và rỗng khi TOP = -1 ) . Bây giờ để nạp đạn thì chúng ta phải kiểm tra thử là buồng đạn đã đầy chưa nếu chưa thì nhận vào một viên và tăng TOP lên 1 giá trị . Để loại bỏ 1 viên đạn ra ngoài thì chúng ta phải kiểm tra xem thử là có còn đạn không ( hay là buồng đạn không rỗng ) nếu thỏa thì ta loại ra 1 viên và hạ TOP xuống .

    Như vậy để cài đặt 1 stack thường thì chúng ta có các hàm cơ bản để thực hiện yêu cầu như sau :
    1. Hàm dùng để khởi động cho 1 stack , với giá trị TOP = -1 . Cái này ta có thể để trong main()
    2. Hàm dùng để kiểm tra stack có bị rỗng không ? (TOP = -1 )
    3. Hàm dùng để kiểm tra stack có bị đầy không ? ( TOP +1 = MAX)
    4. Hàm dùng để đặt vào 1 nút cho stack nếu stack chưa bị đầy !
    5. Hàm dùng để loại bỏ 1 nút nếu stack không rỗng !
    6. Hàm dùng để truy xuất thông tin của một nút nếu stack không rỗng .

    Trong các ebook mà kidkid đọc được thì phần lớn người ta viết các hàm kiểm tra stack có bị rỗng hay đầy riêng rồi truyền đối vào ? Tuy nhiên theo kidkid nghĩ thì với cách viết sử dụng mảng một chiều như chúng ta thì nên kiểm tra trực tiếp trong hàm đặt vào và loại ra luôn !

    Dưới đây là code kidkid đã viết cho các bạn ! Phân tích cho kĩ nha !

    C++ Code:
    1. // stack setup by C that use struct and one way array !
    2. #include "stdafx.h"
    3. #include "stdio.h"
    4. #define MAX 10
    5.  
    6. typedef struct
    7. {            
    8.              char Name[30];
    9.              int age;
    10. }IMFORMATION;
    11. typedef struct
    12. {   int top;               
    13.     IMFORMATION node[MAX];
    14. }STACK;
    15.  
    16. //---------------------------------- declae these funtion that were used in program.
    17.  
    18. void InputData(IMFORMATION &data)
    19. {
    20.     puts("Hi ! What student's name");
    21.     gets(data.Name);
    22.     puts("How old is student");
    23.     scanf("%d",&data.age);
    24.     fflush(stdin);
    25. }
    26.  // this funtion use for receive a node
    27. //  if stacks don't full
    28. void push(STACK &s)
    29. {
    30.     if(s.top == MAX)        // check stack is full or not
    31.     { printf("Stack over flow !");
    32.       return ;
    33.     }
    34.     printf("Student nume %d",s.top+2);
    35.     InputData(s.node[++s.top]); // set up data student to next node
    36. }
    37.  
    38. void pop(STACK &s)          // Deletion a node
    39. {
    40.     if(s.top == -1 )        // check stack is empty or not
    41.     {
    42.         puts("Stack under flow !");
    43.         return ;
    44.     }
    45.     --s.top;
    46. }
    47.  
    48. void stacktop(STACK  &s)
    49. {
    50.     if(s.top == -1 )        // check stack is empty or not
    51.     {
    52.         puts("Stack under flow !");
    53.         return ;
    54.     }
    55.    
    56.     printf("Student number %d\n",s.top);
    57.     puts(s.node[s.top].Name);
    58.     printf("%d\n",s.node[s.top].age);
    59. }
    60. int main(int argc, char* argv[])
    61. {
    62.  
    63.     //  to start for stack
    64.     STACK s;        //  make a statement a s variable of STACK struct ;
    65.     s.top = -1 ;    //  top=1 same as stack is empty .
    66.    
    67.     push(s);
    68.     stacktop(s);
    69.     pop(s);
    70.     pop(s);
    71.  
    72.     return 0;
    73. }
    Tất nhiên code trên về một khía cạnh nào đó thì không được hay lắm . Ví dụ như nếu tui muốn nhập vào nut thứ 11 thì sao ? Cũng như mọi người kidkid cũng suy nghĩ đắn đo lắm để trả lời câu hỏi này và cuối cùng cũng đã tìm ra bằng cách cấp phát thêm cho mảng như chính những gì DSLK đã làm . Tất nhiên là khi chạy vẫn tuyệt như DSLK vậy , mặc dù nó không được phổ biến vì không phải là cách chính qui nhưng kidkid tin rằng dù sao đó vẫn là 1 điều quí báu . Do đó kidkid để dành điều quí báu ấy lại cho chính các bạn đó . Hãy khám phá nào !

    Trong bài tiếp theo kidkid sẽ giới thiệu với các bạn về queue còn bi giờ thì ngủ đã . Chúc các bạn của kidkid học tốt !
    Đã được chỉnh sửa lần cuối bởi iamvtn : 16-11-2007 lúc 12:56 AM.

Các đề tài tương tự

  1. Giáo trình Stack và Queue, có code minh họa
    Gửi bởi vitbau1412 trong diễn đàn Tài liệu, ebooks và công cụ
    Trả lời: 8
    Bài viết cuối: 21-08-2013, 04:00 PM
  2. Xây dựng chương trình mô phỏng: Danh sách liên kết, stack, queue?
    Gửi bởi cherry0103 trong diễn đàn Thắc mắc lập trình C#
    Trả lời: 2
    Bài viết cuối: 28-06-2012, 11:49 PM
  3. Bài tập stack & queue ai giúp với
    Gửi bởi conglam92 trong diễn đàn Nhập môn lập trình C/C++
    Trả lời: 4
    Bài viết cuối: 17-03-2012, 10:37 PM
  4. Danh sách bài tập C++ cơ bản về con trỏ, stack and queue
    Gửi bởi K9K trong diễn đàn Thắc mắc lập trình C/C++/C++0x
    Trả lời: 6
    Bài viết cuối: 12-09-2011, 03:35 PM
  5. Duyệt đồ thị theo chiều sâu dùng stack (help me!!!)
    Gửi bởi rong3sao trong diễn đàn Thắc mắc lập trình C/C++/C++0x
    Trả lời: 1
    Bài viết cuối: 03-02-2010, 10:09 PM

Quyền hạn của bạn

  • Bạn không thể gửi đề tài mới
  • Bạn không thể gửi bài trả lời
  • Bạn không thể gửi các đính kèm
  • Bạn không thể chỉnh sửa bài viết của bạn