bronya1465124479 2022-12-21 16:33 采纳率: 82.6%
浏览 15
已结题

不知道为什么gets函数没有输入if也没判断就直接进入了insert函数,希望有人能解答一下

问题遇到的现象和发生背景

程序目的给链表插入新的节点
主函数中不知道为什么gets函数没有输入if也没判断就直接进入了insert函数,希望有人能解答帮忙改正一下

遇到的现象和发生背景,请写出第一个错误信息
用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

struct node
{
    int ID, score;
    struct node* next;
};

int main()
{
    struct node* creat(struct node* head, int n);
    struct node* insert(struct node* head);
    void print(struct node* head);
    struct node* head = NULL;
    int n; 
    char str[10],a[10]="yes",b[10]="no";
    printf("please enter n\n");
    scanf_s("%d", &n);
    head = creat(head, n);
    printf("Do you want to insert a student's score?(enter yes or no)\n");//主函数从这段开始出问题不知道为什么gets函数没有输入if也没判断就直接进入insert函数
    gets_s(str);
    if ((strcmp(str, a) == 0)||(strcmp(str,b)!=0)) {
        head = insert(head);
        print(head);
    }
}
struct node* creat(struct node* head,int n)//链表的构造
{
    struct node* p = NULL, * q = NULL;
    int i;
    for (i = 1; i <= n; i++) {
        q = (struct node*)malloc(sizeof(struct node));
        printf("please enter %dth ID score\n", i);
        scanf_s("%d %d", &q->ID, &q->score);
        q->next = NULL;
        if (head == NULL) {
            head = q;
        }
        else {
            p->next = q;
        }
        p = q;
    }
    return head;
}
struct node *insert(struct node* head)//链表插入新节点的函数(序号是按照小到大排序输入)
{
    struct node* y =NULL, * q = NULL,*p=head;
    y = (struct node*)malloc(sizeof(struct node));
    printf("please enter ID and score of the student\n");
    scanf_s("%d %d", &p->ID, &p->score);
    if (p->ID > y->ID) {     //新节点插入表头之前
        head = y;
        y->next = p;
    }
    while (p != NULL && p->ID < y->ID) {
        q = p;
        p = p->next;
    }
    if (p != NULL) {          //新节点插入表中
        q->next = y;
        y->next = p;
    }
    else {                    //新结点插入表尾
        q->next = y;
    }
    return head;
}
void print(struct node* head)//输出链表
{
    struct node *p = head;
    while (p != NULL) {
        printf("ID:%d  score:%d\n", p->ID, p->score);
        p = p->next;
    }
}

运行结果及详细报错内容

img

我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%
我想要达到的结果,如果你需要快速回答,请尝试 “付费悬赏”
  • 写回答

2条回答 默认 最新

  • Huazie 全栈领域优质创作者 2022-12-21 16:55
    关注
    • gets_s(str); 接收了上面的 整数输入之后的一个换行, 你要用 getchar() 接收一下换行符才行
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月29日
  • 已采纳回答 12月21日
  • 创建了问题 12月21日

悬赏问题

  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 AT89C51控制8位八段数码管显示时钟。
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题