m0_68396682 2022-11-18 20:47 采纳率: 88.9%
浏览 59
已结题

关于使用数据结构队列创建贪吃蛇的问题

需要设计一个顺序循环队列,长度len为10,队列中有n个元素(1≤n<10)。选择任意一个元素为蛇的头部,队尾元素为蛇的尾部。贪吃蛇开始移动吃他前面的元素,并追加至蛇的尾部,使蛇变长。

第1行,第1个数为一串整形数字,第2个元素表示队头元素的下标值。
第2行,第1个数表示蛇头部的元素,第2个数表示蛇头部元素的下标值。

输入样例
123456789 0
3 2
输出样例
134567892
3 1
345678921
3 0

本人学艺不精,只会队列的入队出队,请问如何在该代码的基础上将其修改为符合题目的需求

#include<stdio.h>
#include<stdlib.h>

struct queue{
    int Data[100];
    int Rear;
    int Front;
};
void Createqueue(struct queue *q)
{
    q->Rear = -1;
    q->Front = -1;
}
void Addqueue(struct queue *q, int x)
{
    q->Rear++;
    q->Data[q->Rear] = x;
}
int Outqueue(struct queue *q)
{
    q->Front++;
    return q->Data[q->Front];    
}
int Isqueue(struct queue *q) 
{
    int i;
    if(q->Rear == q->Front) {
        i = 0;
    }
    else {
        i = 1;
    }

    return i;
} 
int main()
{
    struct queue Qa;
    Createqueue(&Qa);
    int i; 
    for(i = 0;i<9;i++)
    {
        Addqueue(&Qa,i);
    }
    while(Isqueue(&Qa))
    {
    int    k = Outqueue(&Qa);
        printf("%d",k);
    }
    
    
}
  • 写回答

3条回答 默认 最新

  • 关注

    代码如下:

    
    #include <stdio.h>
    #define LEN 10
    struct queue {
        int Data[LEN];
        int Rear;
        int Front;
    };
    
    void InitQueue(struct queue* q)
    {
        for(int i=0;i<LEN;i++)
            q->Data[i] = -1;
    }
    
    //输出
    void show(struct queue* q,int head)
    {
        int i,j;
        for(i=head,j=0;j<LEN;i++,j++)
        {
            if(q->Data[i%LEN] != -1)
                printf("%d",q->Data[i%LEN]);
        }
        printf("\n");
    }
    
    
    
    int main()
    {
        char str[12] = { 0 };
        int qhead; //对头位置
        int sn, snindex; //蛇头元素和蛇头下标
        int i, v, size = 0;
        struct queue Qa;
        InitQueue(&Qa); //初始化队列
        scanf("%s %d", str, &qhead);
        scanf("%d %d", &sn, &snindex);
        Qa.Front = qhead; //队头
    
        //将数字串放入队列
        for (i = 0; str[i] != '\0'; i++)
            Qa.Data[(qhead+i)%LEN] = str[i]-'0'; //循环排放
        
        
        //如果队头下标==蛇头下标,直接输出即可
        if (qhead == snindex)
        {
            show(&Qa,qhead);
            printf("%d %d\n", sn, snindex);
            return 0;
        }
        else
        {
            //如果队头==0
            if (qhead == 0)
            {
                //队尾肯定在最后,所以蛇头直接向前移动即可
                while (snindex > qhead)
                {
                    //队列数据前移
                    v = Qa.Data[snindex - 1];
                    for (i = snindex; i < LEN; i++)
                        Qa.Data[i - 1] = Qa.Data[i];
                    Qa.Data[LEN - 1] = v;
                    snindex--;
                    //输出蛇元素
                    show(&Qa,qhead);
                    printf("%d %d\n", sn, snindex);
                }
            }
            else
            {
                // 对头下标不为0,队尾肯定在头的左侧
                Qa.Rear = Qa.Front - 1;
                //如果蛇头初始位置在队尾的左侧
                if (snindex <= Qa.Rear)
                {
                    //先向左侧
                    while (snindex > 0)
                    {
                        v = Qa.Data[snindex - 1];
                        for (i = snindex; i <= Qa.Rear; i++)
                            Qa.Data[i - 1] = Qa.Data[i];
                        Qa.Data[Qa.Rear] = v;
                        snindex--;
                        //打印
                        show(&Qa,qhead);
                        printf("%d %d\n", sn, snindex);
                    }
                    //snindex == 0
                    v = Qa.Data[LEN-1]; //
                    Qa.Data[LEN-1]= Qa.Data[0];
                    for(i=0;i<Qa.Rear;i++)
                        Qa.Data[i] = Qa.Data[i+1];
                    Qa.Data[Qa.Rear] = v;
                    snindex = LEN - 1;
                    show(&Qa,qhead);
                    printf("%d %d\n",sn,snindex);
    
                    //左侧吃完后,绕到数组末尾开始
                    
                    while (snindex > qhead)
                    {
                        v = Qa.Data[snindex - 1];
                        //蛇头后半部分移动
                        for (i = snindex; i < LEN; i++)
                            Qa.Data[i - 1] = Qa.Data[i];
                        Qa.Data[LEN - 1] = Qa.Data[0];
                        for (i = 0; i < Qa.Rear; i++)
                            Qa.Data[i] = Qa.Data[i + 1];
                        Qa.Data[Qa.Rear] = v;
                        snindex--;
                        if (v == -1)
                            continue;
                        show(&Qa,qhead);
                        printf("%d %d\n", sn, snindex);
                    }
                }
                else
                {
                    //蛇头在队尾的右侧
                    //size = LEN - (snindex - qhead); //初始蛇身长度(含-1)
                    while (snindex > qhead)
                    {
                        v = Qa.Data[snindex - 1];
                        //蛇头后半部分移动
                        for (i = snindex; i < LEN; i++)
                            Qa.Data[i - 1] = Qa.Data[i];
                        Qa.Data[LEN - 1] = Qa.Data[0];
                        for (i = 0; i < Qa.Rear; i++)
                            Qa.Data[i] = Qa.Data[i + 1];
                        Qa.Data[Qa.Rear] = v;
                        snindex--;
                        show(&Qa,qhead);
                        printf("%d %d\n", sn, snindex);
                    }
                }
            }
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    1人已打赏
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月20日
  • 已采纳回答 11月19日
  • 修改了问题 11月18日
  • 创建了问题 11月18日

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?