civil_dog985 2021-08-16 17:32 采纳率: 50%
浏览 97
已结题

C++学生信息系统 链表运行中止


#include <iostream>
#include <string>
#include <stdio.h>
using namespace std;

typedef struct Student {
    string number;
    string name;
}st;
typedef struct node {
    st data;
    struct node* next;
}Node,*Link;

void input(Link l) {
    cout << "please enter the student's number: ";
    cin >> l->data.number;
    cout << "please enter the student's name : ";
    cin >> l->data.name;
    l->next = NULL; //!!重要 //#include <stdio.h>
}
bool insert(Link head){
    Link p, q;
    Link node;
    node = (Link)malloc(sizeof(Node));
    input(node);
    q = head;
    p = head->next;
    if (head->next == NULL)
        head->next = node;
    else{
        while (p != NULL) {
            if (node->data.number < p->data.number /**/ && node->data.number>q->data.number) {
                q->next = node;
                node->next = p;
                return true;
            }
            else {
                q = p;
                p = p->next;
            }
        }
        q->next = node;//q而不是p,p已经是NULL了!
    }
    return true;
}
void show(Link head,string numnam) {
    Link p;
    p = head->next;
    while (p != NULL) {
        if (p->data.name == numnam || p->data.number == numnam) {
            cout << "找到该学生相关信息如下:\n";
            cout << "name:" << p->data.name << endl
                << "number:" << p->data.number << endl;
            break;
        }
        else {
            p = p->next;
        }
    }
    cout << "未找到该学生!\n";
}
void showall(Link head) {
    Link p;
    p = head->next;
    cout << "找到所有学生相关信息如下:\n";
    while (p != NULL) {
            cout << "name:" << p->data.name << endl
                << "number:" << p->data.number << endl;
            p = p->next;
    }
    cout << "所有学生信息显示完毕!\n";
}
void modifyname(Link head, string numnam) {
    Link p;
    p = head->next;
    while (p != NULL) {
        if (p->data.name == numnam || p->data.number == numnam) {
            cout << "请输入修改后的学生姓名:\n";
            cin >> p->data.name;
        }
        else {
            p = p->next;
        }
    }
    cout << "修改失败,未找到该学生!\n";
}
int main() {
    Link head;
    head = (Link)malloc(sizeof(Node));
    head->next = NULL;
    int n;
    cout << "您需要输入多少学生信息?:";
    cin >> n;
    for (int i = 0; i < n; i++)
        cout << insert(head);
    cout << "所有学生信息如下:\n";
    showall(head);
    return 0;
}

img

img
求大lao告知我的链表代码哪里出错了
求球啦!九救 子亥 子 吧

  • 写回答

4条回答 默认 最新

  • orange4reg 2021-08-16 19:22
    关注

    因为你head没有初始化,第一次insert直接插到head后面没有问题,但是后面的insert的时候又用到head,固然下面那个比较就有可能不成立了。因为head没有初始化,里面的值未知。
    if (node->data.number < p->data.number /**/ && node->data.number>q->data.number)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 无源定位系统的时差估计误差标准差
  • ¥15 请问这个代码哪里有问题啊
  • ¥20 python--version在命令端输入结果Python is not defined怎么办?还有pip不是exe格式是不是没安装成功?
  • ¥15 通过GaussianView进行结构微调消除虚频
  • ¥15 调用transformers库
  • ¥15 由于导出的数据名字中带有/,导致Matlab打不开,怎么办?
  • ¥15 新硬盘安装的程序总是崩溃,提示遇到错误
  • ¥15 openpcdet自制数据集评估bev精度和3d精度相同
  • ¥15 excel 上下按钮 显示行
  • ¥20 云卓h12pro 数传问题