鱼C论坛

 找回密码
 立即注册
查看: 724|回复: 0

[技术交流] C语言程序设计练习之链表--数据库/实现录入,删除和添加

[复制链接]
发表于 2020-7-22 20:55:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
#include<stdlib.h>
#include<iostream>
#include<cmath>
#include<math.h>
#include<string.h>

#define LEN sizeof(struct man)
struct man
{
        int num;
        float score;
        struct man* next;
};
struct man* creat();
struct man* deletes(struct man *head);
struct man *adds(struct man* head,struct man *stu);
void prints(struct man* head);
int main()
{
        struct man* trans, * transs, * transss;
        trans = creat();
        prints(trans);
        int i = 0;
        for (;;)
        {
                printf("if you wanna delete a data please enter 1,if wanna add a data enter 2,leave enter 3\n");
                scanf_s("%d", &i);
                if (1 == i)
                {
                        transs = deletes(trans);
                        prints(transs);
                        trans = transs;
                }
                if (2 == i)
                {
                        struct man stu;
                        printf("please enter num to add:\n");
                        scanf_s("%d", &stu.num);
                        printf("please enter a score for num:%d\n", stu.num);
                        scanf_s("%f", &stu.score);
                        transss = adds(trans,&stu);
                        prints(transss);
                        trans = transss;
                }
                if (3 == i)
                {
                        break;
                }
        }
        system("pause");
        return 0;
}
int n;
//struct man* head;
struct man* creat()
{
        struct man* head;
        struct man* p1, * p2;
        p1 = p2 = (struct man*)malloc(LEN);
        printf("please enter a num:\n");
        scanf_s("%d", &p1->num);
        printf("please enter score\n");
        scanf_s("%f", &p1->score);
        head = NULL;
        n = 0;
        while (p1->num)
        {
                n = n + 1;
                if (1 == n)
                {
                        head = p1;
                }
                else
                {
                        p2->next = p1;
                }
                p2 = p1;
                p1 = (struct man*)malloc(LEN);
                printf("please enter a num\n");
                scanf_s("%d", &p1->num);
                printf("please enter a score:\n");
                scanf_s("%f", &p1->score);
        }
        p2->next = NULL;
        return (head);
}

void prints(struct man* head)
{
        //struct man* p;
        //p = head;
        if (head == NULL)
        {
                printf("sorry this a null list.\n");
        }
        printf("record:%d\n\n", n);
        do
        {
                printf("num:%d, score:%f\n", head->num, head->score);
                head =head->next;
        } while (head);
        printf("print succeed!thank for using\n\n");
}

struct man* deletes(struct man *head)
{
        struct man* p1, * p2;
        p1 = p2 = head;
        int j = 0;
        printf("please enter serial num to delete:\n");
        //getchar();
        scanf_s("%d", &j);
        while (p1->num != j && p1->next != NULL)
        {
                p2 = p1;
                p1 = p1->next;
        }
                if (head == NULL)
                {
                        goto END;
                }
                if (p1->num == j)
                {
                        if (p1 == head)
                        {
                                head = p1->next;
                        }
                        else
                        {
                                p2->next = p1->next;
                        }
            printf("delete succeed.\n\n");
            n = n - 1;
                }
                else
                {
                        printf("no found data to delete\n\n");
                }
       
  END:
  return (head);
}

struct man *adds(struct man* head, struct man *stu)
{
        struct man* p0, * p1, * p2;
        //p0 = stu;
        p0 = (struct man*)malloc(LEN);
        *p0 = *stu;
        p2=p1 = head;
        if (NULL == head)
        {
                head = p0;
                p0->next = NULL;
        }
        else
        {
                while ((p0->num > p1->num) && (p1->next != NULL))
                {
                        p2 = p1;
                        p1 = p1->next;
                }
                if (p0->num <= p1->num)
                {
                        if (head == p1)
                        {
                                head = p0;
                        }
                        else
                        {
                                p2->next = p0;
                        }
                        p0->next = p1;
                }
                else
                {
                        p1->next = p0;
                        p0->next = NULL;
                }
        }
        n = n + 1;
        return (head);
}&#128513;
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 10:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表