| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1481 人关注过本帖
标题:输入的时候只能输一组,大神求助
只看楼主 加入收藏
tian小韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-26
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:8 
输入的时候只能输一组,大神求助
#include<stdio.h>
#include<stdlib.h>
#define SIZE sizeof(struct student)
struct student
{
    long int num;
    char name[20];
    char sex;
    int age;
    struct student *next;
};
struct student *create()
{
    struct student *head,*p1,*p2;
    head=NULL;
    p1=(struct student *)malloc(SIZE);
    scanf("%ld%s%c%d",&p1->num,p1->name,&p1->sex,&p1->age);
    while(p1->num!=0)
    {
        if(head=NULL)
            head=p1;
        else
            p2->next=p1;
    p2=p1;
    p1=(struct student *)malloc(SIZE);
    scanf("%ld%s%c%d",&p1->num,p1->name,&p1->sex,&p1->age);
    }
    p2->next=NULL;
    free(p1);
    return head;
}
struct student *delet(struct student *head,int num)
{
    struct student *p1=head,*p2;
    while(p1->num!=num&&p1->next!=NULL)
    {
        p2=p1;
        p1=p1->next;
    }
    if(p1->num==num)
    {
        if(p1==head)
            head=p1->next;
        else
            p2->next=p1->next;
    }
    return head;
}
void print(struct student *head)
{
    struct student *p1;
    p1=head;
    if(head=NULL)
        printf("为空表");
    else
    {
        do
        {
            printf("%ld%s%c%d",p1->num,p1->name,p1->sex,p1->age);
            p1=p1->next;
        }
        while(p1->next!=NULL);
    }
}
void main()
{
    struct student *head;
    long int num;
    head=create();
    printf("原来的链表:");
    print(head);
    printf("Please enter you want deleted:");
    scanf("%ld",&num);
    delet(head,num);
    printf("删除后的链表:");
    print(head);
}

搜索更多相关主题的帖子: include create 
2016-05-26 23:19
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:7 
这里有编译告警啊,p2没有申请空间就直接用了,先解决这个问题吧。
程序代码:
while (p1->num != 0)
    {
        if (head = NULL)
            head = p1;
        else
            p2->next = p1;
        p2 = p1;
        p1 = (struct student *)malloc(SIZE);
        scanf("%ld%s%c%d", &p1->num, p1->name, &p1->sex, &p1->age);
    }
    p2->next = NULL;
2016-05-27 09:08
wanglianyi1
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:14
帖 子:647
专家分:2067
注 册:2015-6-18
收藏
得分:7 
while(p1->num!=0)  这句是什么意思? num是你要输入的学号?
2016-05-27 09:19
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:0 
他是想以输入0表示结束输入。
2016-05-27 09:48
tian小韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-26
收藏
得分:0 
回复 3楼 wanglianyi1
是的
2016-05-27 23:48
tian小韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-26
收藏
得分:0 
回复 2楼 grmmylbs
谢谢你的提醒,不过为什么有的不用给P2开辟空间啊,它应该只是一个结构体指针变量吧

#include<stdio.h>
#include<stdlib.h>
#define SIZE sizeof(struct student)
struct student
{
    long int num;
    char name[20];
    char sex;
    int age;
    struct student *next;
};
struct student *create()
{
    struct student *head,*p1,*p2;
    head=NULL;
    p1=(struct student *)malloc(SIZE);
    scanf("%ld%s%c%d",&p1->num,p1->name,&p1->sex,&p1->age);
    while(p1->num!=0)
    {
        if(head=NULL)
            head=p1;
        else
            p2->next=p1;
    p2=p1;
    p1=(struct student *)malloc(SIZE);
    scanf("%ld%s%c%d",&p1->num,p1->name,&p1->sex,&p1->age);
    }
    p2->next=NULL;
    free(p1);
    return head;
}
struct student *delet(struct student *head,int num)
{
    struct student *p1=head,*p2;
    while(p1->num!=num&&p1->next!=NULL)
    {
        p2=p1;
        p1=p1->next;
    }
    if(p1->num==num)
    {
        if(p1==head)
            head=p1->next;
        else
            p2->next=p1->next;
    }
    return head;
}
void print(struct student *head)
{
    struct student *p1;
    p1=head;
    if(head=NULL)
        printf("为空表");
    else
    {
        do
        {
            printf("%ld%s%c%d",p1->num,p1->name,p1->sex,p1->age);
            p1=p1->next;
        }
        while(p1->next!=NULL);
    }
}
void main()
{
    struct student *head;
    long int num;
    head=create();
    printf("原来的链表:");
    print(head);
    printf("Please enter you want deleted:");
    scanf("%ld",&num);
    delet(head,num);
    printf("删除后的链表:");
    print(head);
}
2016-05-27 23:53
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:7 
*p2是指向已经开辟好的*p1所在的结构体位置,


[此贴子已经被作者于2016-5-28 08:32编辑过]

2016-05-28 08:29
tian小韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-26
收藏
得分:0 
回复 7楼 linlulu001
所以它应不应该再开辟空间?
2016-05-28 10:25
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
回复 8楼 tian小韵
你写的是链表,简单来说*p2是一个中间值,不需要空间,只要指针的类型对就行了。
2016-05-28 14:56
快速回复:输入的时候只能输一组,大神求助
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020979 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved