当前位置:首页 > 算法 > 正文内容

队列算法应用

浩雨5年前 (2019-10-28)算法9978

image.png

#include<stdio.h>
#define MAXSIZE 100
typedef char DataType;
typedef struct{
    DataType data[MAXSIZE];
    int front; //队头下标 
    int rear; //队尾下标 
}SeqQueue;
 
/*初始化队列*/
void InitQueue(SeqQueue *Q){
    Q->front = Q->rear=0;
}
 
/*判断队空*/
int EmptyQueue(SeqQueue *Q){
    if(Q->front == Q->rear)
       return 1;
    else
       return 0;
}
 
/*入队*/
int InQueue(SeqQueue *Q,DataType x){
    if((Q->rear+1)%MAXSIZE == Q->front){
       printf("队满,不能入队!");
       return 0;
    }
    else{
       Q->rear = (Q->rear+1) % MAXSIZE;
       Q->data[Q->rear] = x;
       return 1;
    }
}
 
/*出队*/
int DeQueue(SeqQueue *Q,DataType *x){
    if(EmptyQueue(Q)){
       printf("队空,不能出队!");
       return 0;
    }
    else{
       Q->front = (Q->front+1)%MAXSIZE; //队头指针增1 
       *x = Q->data[Q->front]; //队头元素赋给指针x的变量
       return 1; 
    }
}
 
/*取队头元素*/
int GetFront(SeqQueue *Q,DataType *x){
    if(EmptyQueue(Q)){
       printf("队空,无队头元素!");
       return 0;
    }
    else{
       *x = Q->data[(Q->front+1) % MAXSIZE];
       return 1;
    }
}
 
/*显示队列元素*/
void ShowQueue(SeqQueue *Q){
    int p=Q->front;
    if(p == Q->rear){
       printf("队列为空,无元素!");
    }
    else{
       printf("从队头起,队列中的元素为:");
       while(p != Q->rear){
           p = (p+1)%MAXSIZE;
           printf("%c",Q->data[p]);
       }
    }
}
 
void Menu()
{
        printf("\n       队列的各种操作");
       printf("\n===================================================");
       printf("\n|      1--初始化队列                              |");
       printf("\n|      2--调用入队函数                            |");
       printf("\n|      3--调用出队函数,输出队列Q中指定的个数     |");
       printf("\n|      4--输出此时的队头元素                      |");
       printf("\n|      5--调用显示函数,输出顺序队列Q             |");
       printf("\n===================================================");   
       printf("\n请输入菜单号(0-5):");
}
main(){
    int i,n,flag;
    SeqQueue Q;
    DataType x;  //char x
    char ch1,ch2,a;
    ch1 = 'y';
    while(ch1 == 'y' || ch1 == 'Y'){
       Menu();
       scanf(" %c",&ch2);
       getchar();
       switch(ch2){
           case '1':
              InitQueue(&Q);
              printf("队的初始化完成!");
              break;
           case '2':
              printf("请输入入队元素的个数:");
              scanf("%d",&n);
              printf("请输入%d个入队的字符",n);
              for(i=0; i<n; i++){
                  scanf(" %c",&x);
                  flag = InQueue(&Q,x);
              }
              if(flag == 1)
                  printf("入队成功!");
              else
                  printf("入队失败!");
              break;
           case '3':
              printf("请输入要出队元素的个数:");
              scanf("%d",&n);
               printf("出队的元素顺序依次为:");
              for(i=0; i<n; i++){
                  flag = DeQueue(&Q,&x);
                  printf("%c",x);
              }
              if(flag == 1)
                  printf("出队成功!");
              else
                  printf("出队失败!");
              break;
           case '4':
              if(flag = GetFront(&Q,&x))
                  printf("当前队头元素为:%c",x);
              break;
           case '5':
              ShowQueue(&Q);
              break;
           case '0':
              ch1 = 'n';
               break;
           default:
              printf("输入有误!请重新输入!");
       }
    }
}



扫描二维码推送至手机访问。

版权声明:本文由我的FPGA发布,如需转载请注明出处。

本文链接:https://world.myfpga.cn/index.php/post/33.html

分享给朋友:

“队列算法应用” 的相关文章

顺序表算法应用

顺序表算法应用

利用顺序表数据类型解决实际问题,内容如下:(1) 定义顺序表结构数组对象,最多能存100个数据;(2) 调用创建函数初始化顺序表为1,5,96,45,3,6,4,88,7,36(3) 调用输出函数,要求输出当前这个数据结构中的所有数据;(4) 调用插入函数,要求在当前存放数据的第一个位置插入一个值为...

Hanoi Tower问题的简单实现

Hanoi Tower问题的简单实现

设A,B,C是3个塔座。开始时,在塔座A上有一叠共n个圆盘,这些圆盘自上而下,由小到大地叠在一起。各圆盘从小到大编号为1,2,…,n,现要求将塔座A上的这一叠圆盘移到塔座C上,并仍按同样顺序叠置。在移动圆盘时应遵守以下移动规则:(1)每次只能移动1个圆盘;(2)任何时刻都不允许将较大的圆盘压在较小的...

常见算法的C语言实现(带题目、分析和答案) 穷举 递归 迭代 递推 分治 回溯 动态规划 贪心

常见算法的C语言实现(带题目、分析和答案) 穷举 递归 迭代 递推 分治 回溯 动态规划 贪心

1.1   基本思想1.1.1  穷举穷举(又称枚举)算法的基本思想是从所有可能的情况中搜索正确的答案。a)      题一查找数组中的两个元素,它们的和等于给定的目标值。给定一个包含 n 个整数的数组和一个目标值,找出...

(LeetCode刷题)1. 两数之和

(LeetCode刷题)1. 两数之和

题目解答一:/**  * Note: The returned array must be malloced, assume caller calls free(). &nbs...

(LeetCode刷题)2. 两数相加

(LeetCode刷题)2. 两数相加

题目解答一:简单实现思路:先遍历完两个链表,把各自的数字存入两个数组,然后对应位置的数相加,若结果大于10就进位到更高位的数。/**  * Definition for singly-linked list->  * s...

(LeetCode刷题)3. 无重复字符的最长子串

(LeetCode刷题)3. 无重复字符的最长子串

题目:解法一:class Solution(object):     def lengthOfLongestSubstring(self,s):        &nb...