zoukankan      html  css  js  c++  java
  • 第10章,基本数据结构(栈,队列)

    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    
    typedef struct _stack{
    	int* arr;
    	int top, size;
    }stack;
    stack createStack(int size)
    {
    	stack st;
    	st.arr = (int*)malloc(size*sizeof(int));
    	st.top = -1;
    	st.size = size;
    	return st;
    }
    int isEmptyStack(stack &s)
    {
    	return s.top == -1;
    }
    void push(stack &s, int val)
    {
    	if (s.top == s.size - 1){
    		int *tmp = s.arr;
    		s.arr = (int*)malloc(2 * s.size*sizeof(int));
    		memcpy(s.arr, tmp, s.size*sizeof(int));
    		s.size = s.size * 2;
    	}
    	++s.top;
    	s.arr[s.top] = val;
    }
    int pop(stack &s)
    {
    	if (isEmptyStack(s)){
    		printf("stack is empty
    ");
    		exit(-1);
    	}
    	--s.top;
    	return s.arr[s.top + 1];
    }
    
    
    typedef struct _queue{
    	int *arr;
    	int tail, head, size;
    }queue;
    queue createQueue(int size)
    {
    	queue q;
    	q.tail = q.head = 0;
    	q.arr = (int*)malloc(size*sizeof(int));
    	q.size = size;
    	return q;
    }
    void enqueue(queue &q, int val)
    {
    	if (q.head == (q.tail + 1) % q.size){
    		int *tmp = q.arr;
    		q.arr = (int*)malloc(2 * q.size*sizeof(int));
    		memcpy(q.arr, tmp, q.size*sizeof(int));
    		q.size = 2 * q.size;
    	}
    	q.arr[q.tail] = val;
    	q.tail = (q.tail + 1) % q.size;
    }
    int dequeue(queue &q)
    {
    	if (q.tail == q.head){
    		printf("queue is empty
    ");
    		exit(-1);
    	}
    	int res = q.arr[q.head];
    	q.head = (q.head + 1) % q.size;
    	return res;
    }
    
    int main()
    {
    	int a[] = { 1, 2, 3, 4, 5, 6, 7 };
    	stack ss = createStack(5);
    	for (int i = 0; i < 7; ++i)
    		push(ss, a[i]);
    	printf("%d
    ", ss.size);
    	for (int i = 0; i < 7; ++i)
    		printf("%d	", pop(ss));
    	printf("
    ");
    
    	queue q = createQueue(5);
    	for (int i = 0; i < 5; ++i)
    		enqueue(q, a[i]);
    	dequeue(q); dequeue(q);
    	enqueue(q, 100); enqueue(q,200);
    	for (int i = 0; i <6; ++i)
    		printf("%d	", dequeue(q));
    }
    

      

  • 相关阅读:
    LINQ查询操作符之First、FirstOrDefault、Last、LastOrDefault、ElementAt、ElementAtOrDefault、Contains、Any、All、Coun
    .Net 使用的快捷键
    P2073 送花
    洛谷P1514 引水入城
    花园
    八数码难题
    并查集题目整理
    树链剖分(强势借鉴)
    模拟题
    考试整理
  • 原文地址:https://www.cnblogs.com/jokoz/p/4696505.html
Copyright © 2011-2022 走看看