队列

#include<stdio.h>
#include<stdlib.h>
#define QUEUE_INIT_SIZE 10
#define OVERFLLOW 1
#define ERROR 0
#define OK 1
#define STACKINCREMENT 10
#define TURE 1
#define FALSE 0


typedef int elemtype;

typedef struct queue Squ;

struct queue {

    elemtype front;  

    elemtype *value;

    elemtype rear;
};

 void InitQueue(Squ *q)
{
    
     q->value=(elemtype *)malloc(QUEUE_INIT_SIZE * sizeof(elemtype));
     if(q->value == NULL) {
         exit(OVERFLLOW);
     }
     q->front = 0;
     q->rear = 0;
}

/*
 *   clear stack if have clear return ok--1;
 */

int ClearQueue(Squ *q)
{
    
     Squ *p=q;
     if( p->front == p->rear ) {
         *p->value=0;
         return OK;
     }
     while(p->front != p->rear) {
         *p->value=0;
         p->front++;
     }
     *p->value=0;
     return OK;
}

/*
 *   if stack is exist but empty return ture ,else return false;
 */

int EmptyQueue(Squ q)
{
    if(q.front == q.rear ) {
        return FALSE;
    } else {
        return TURE;
    }
}

/*
 *  if stack is empty StackLength return 0,else return its length;
 */

int QueueLength(Squ q)
{
    Squ *p=&q;
    int count=0;

    if(p->front == p->rear) {
        return count;
    }
    while(p->front != p->rear) {
        count++;
        p->front++;
    }
    return count;
}

/*
 *  if stack is exist ,return its top member;
 */

int  GetTop(Squ q,elemtype *value)
{
     Squ *p=&q;
     int i=0;
     if(p->front == p->rear) {
         return ERROR;
     } else {
          while(p->front != p->rear) {
              p->front ++;
              p->value[i++];
          }
          *value=p->value[i];
          return TURE;
       }
}
/*
 *   push member into stack;
 */   
int EnQueue(Squ *q,elemtype *value)
{
     if( (q->rear+1) % QUEUE_INIT_SIZE == q->front) {
          printf("the queue is full/n");
          return ERROR;
     } else {
           q->value[q->rear] = *value;
           q->rear=(q->rear+1) % QUEUE_INIT_SIZE;
       }
     return OK;
}  
/*
 * Pop a member from stack,if success return ture,else return false;
 */

int OutQueue(Squ *q,elemtype *value)
{
    if(q->front == q->rear) {
        printf("no data/n");
        return FALSE;
    } else {
          *value=q->value[q->front];
          q->front=(q->front+1) % QUEUE_INIT_SIZE;
      }
    return TURE;
}

/*
 * Destroy the stack,if stack not exist return error,else destroy it
 * and return ture;
 */

int DestroyQueue(Squ *q)
{  
     free(q->value);
     return TURE;
}


  
int main()
{
   elemtype value;
   Squ Queue;
   int i;
   InitQueue(&Queue);
 /*  GetTop(*Queue,&value);
   printf("%d/n",value);
   printf("the queue length is: %d/n",QueueLength(*Queue));
  */
   printf("please input value/n");
   scanf("%d",&value);
   while(value != 0 ) {
       EnQueue(&Queue,&value);
    //   GetTop(Queue,&value);
    //   printf("the top value is:%d/n",value);
       printf("the queue length is:%d/n",QueueLength(Queue));  
       if(! EmptyQueue(Queue)){
           printf("queue is free/n");
        } else {
              printf("queue is not free/n");
          }
       printf("please input value/n");
       scanf("%d",&value);
   }
   //ClearQueue(Queue);
 /*  GetTop(Queue,&value);
   printf("value=:%d/n",value);*/
   printf("please input value!/n");
   scanf("%d",&value);
   while(value !=  0 ) {
       OutQueue(&Queue,&value); 
       printf("%d/n",value);
       printf("the queue length is=:%d/n",QueueLength(Queue));
      
       printf("please input value!/n");
       scanf("%d",&value);
   }
/*
   if(! EmptyQueue(Queue)){
        printf("queue is free/n");
   } else {
         printf("queue is not free/n");
     }

   if(! DestroyQueue(&Queue) ) {
       printf("destroy queue unsuccess/n");
   }  else {
          printf("destroy queue success/n");
      }*/
   return 0;
}     

 

 

 

 

内容概要:该论文深入研究了液压挖掘机动臂下降势能回收技术,旨在解决传统液压挖掘机能耗高的问题。提出了一种新型闭式回路势能回收系统,利用模糊PI自整定控制算法控制永磁无刷直流电动机,实现了变转速容积调速控制,消除了节流和溢流损失。通过建立数学模型和仿真模型,分析了不同负载下的系统性能,并开发了试验平台验证系统的高效性和节能效果。研究还涵盖了执行机构能量分布分析、系统元件参数匹配及电机控制性能优化,为液压挖掘机节能技术提供了理论和实践依据。此外,通过实验验证,该系统相比传统方案可降低28%的能耗,控制系统响应时间缩短40%,为工程机械的绿色化、智能化发展提供了关键技术支撑。 适合人群:从事工程机械设计、制造及维护的工程师和技术人员,以及对液压系统节能技术感兴趣的科研人员。 使用场景及目标:①理解液压挖掘机闭式回路动臂势能回收系统的原理和优势;②掌握模糊PI自整定控制算法的具体实现;③学习如何通过理论建模、仿真和实验验证来评估和优化液压系统的性能。 其他说明:此研究不仅提供了详细的理论分析和数学建模,还给出了具体的仿真代码和实验数据,便于读者在实际工作中进行参考和应用。研究结果表明,该系统不仅能显著提高能源利用效率,还能延长设备使用寿命,降低维护成本,具有重要的工程应用价值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值