灼美丽小苗苗 2022-10-07 20:29 采纳率: 55.6%
浏览 38
已结题

环形队列使用指针导致错误了

//环形队列
// 不知道 哪里不对 了
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#define max 10
typedef struct Queue {
    int current;
    int store[max];
    int* begin, * end;
}queue;
queue init(void);//初始化
void push(queue*);//入队列
void pop(queue*);//出队列
void show(queue);//遍历队列元素
int main(void) {
    queue army = init();//初始化一个链表
    push(&army);//此后几行是调试 ,结构发现错误了
    push(&army);
    push(&army);
    pop(&army);
    show(army);
 
    return 0;
}
queue init(void) {
    queue temp;
    temp.current = 0;//现在的元素个数是0
    temp.begin = temp.store;//两个指针都指向 数组
    temp.end = temp.store;
 
    return temp;
}
void push(queue* temp) {
    if (temp->current == max) {//数据存放满
        puts("队列已满,无法入队列");
        exit(-1);
    }
    puts("请输入要入队列的数据");
    int income;
    scanf_s("%d", &income);
    *(temp->end)++ = income;// 在 end 位置写入 数据,然后end指针后移一位 
    printf("%d已入队列\n", *(temp->end - 1));
    temp->current++; //队列数据 +1
    if (temp->end == &(temp->store[max])) {//如果越界
        temp->end = &(temp->store[0]);//指向开头位置
    }
}
void pop(queue* temp) {
    if (temp->current == 0) {
        puts("队列为空,无法出队列");
        exit(-1);
    }
    printf("%d已出队列", *(temp->begin)++);//begin指针读取数字, 然后 后移一位 
    temp->current--;
    if (temp->begin == &(temp->store[max])) {//如果越界
        temp->begin = &(temp->store[0]);//指向开头位置
    }
}
void show(queue temp) {
    printf("temp.current is %d\n", temp.current);
    while(temp.current != 0) {
        if (temp.begin != temp.store) {
            printf("--%d--", *(temp.begin));
            temp.begin++;
        }
        temp.current--;
    }
}

  • 写回答

1条回答 默认 最新

  • X-道至简 2022-10-07 21:06
    关注

    这个init是不对的, 如果返回一个形参 begin和end的值会乱掉的,只是值拷贝。 要malloc返回一个地址
    queue army = init(); 这句话运行后会产生一个先的变量,地址是改了的。
    先把这个改了试试

    queue init(void) {
        queue temp;
        temp.current = 0;//现在的元素个数是0
        temp.begin = temp.store;//两个指针都指向 数组
        temp.end = temp.store;
     
        return temp;
    

    main函数这样改了一下输出好像对了

    int main(void) {
        //queue army = init();//初始化一个链表
        queue army;
        army.current = 0;//现在的元素个数是0
        army.begin = army.store;//两个指针都指向 数组
        army.end = army.store;
    
        push(&army);//此后几行是调试 ,结构发现错误了
        push(&army);
        push(&army);
        pop(&army);
        show(army);
    
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 10月16日
  • 已采纳回答 10月8日
  • 创建了问题 10月7日

悬赏问题

  • ¥15 VS2022 C++的相关代码问题咨询
  • ¥15 如果要做一个老年人平板有哪些需求
  • ¥15 k8s生产配置推荐配置及部署方案
  • ¥15 matlab提取运动物体的坐标
  • ¥15 人大金仓下载,有人知道怎么解决吗
  • ¥15 一个小问题,本人刚入门,哪位可以help
  • ¥30 python安卓开发
  • ¥15 使用R语言GD包一直不出结果
  • ¥15 计算机微处理器与接口技术相关问题,求解答图片的这个问题,有多少个端口,端口地址和解答问题的方法和思路,不要AI作答
  • ¥15 如何根据一个截图编写对应的HTML代码