第四周项目1 建立单列表

本文详细介绍了如何使用C语言实现单链表的头插法与尾插法建立过程,包括代码实现、功能演示及销毁链表的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>
#include <malloc.h>
typedef int ElemType;
typedef struct LNode        //定义单链表结点类型
{
    ElemType data;
    struct LNode *next;     //指向后继结点
} LinkList;

void CreateListF(LinkList *&L,ElemType a[],int n);//头插法建立单链表
void CreateListR(LinkList *&L,ElemType a[],int n);//尾插法建立单链表
void DestroyList(LinkList *&L); //销毁单链表
void DispList(LinkList *L);  //输出单链表

int main()
{
    LinkList *L1, *L2;
    ElemType a[8]= {7, 9, 8, 2, 0, 4, 6, 3};
    CreateListF(L1, a, 8);
    printf("头插法建表结果:");
    DispList(L1);
    CreateListR(L2, a, 6);
    printf("尾插法建表结果:");
    DispList(L2);
    DestroyList(L1);
    DestroyList(L2);
    return 0;
}

void CreateListF(LinkList *&L,ElemType a[],int n)//头插法建立单链表
{
    LinkList *s;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
    for (i=0; i<n; i++)
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        s->next=L->next;            //将*s插在原开始结点之前,头结点之后
        L->next=s;
    }
}
void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
    r=L;                    //r始终指向终端结点,开始时指向头结点
    for (i=0; i<n; i++)
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        r->next=s;          //将*s插入*r之后
        r=s;
    }
    r->next=NULL;           //终端结点next域置为NULL
}

void DestroyList(LinkList *&L)  //销毁单链表
{
    LinkList *p=L,*q=p->next;
    while (q!=NULL)
    {
        free(p);
        p=q;
        q=p->next;
    }
    free(p);    //此时q为NULL,p指向尾结点,释放它
}

void DispList(LinkList *L)  //输出单链表
{
    LinkList *p=L->next;
    while (p!=NULL)
    {
        printf("%d ",p->data);
        p=p->next;
    }
    printf("\n");
}
void CreateListO(LinkList *&L,ElemType a[],int n)  //建立有序(升序)的单链表
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
    for (i=0; i<n; i++)
    {
        r=L; //r指向头结点
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        s->next=NULL;
        while(r->next!=NULL && r->next->data < a[i])  //找到插入点
            r = r->next;
        s->next=r->next; //将*s插入*r之后
        r->next=s;
    }
}

我是数据湖仓专家,支撑公司数据分析。以下是我的周报,markdown格式的,请帮我提炼,并编写“每月目标和实际达成情况”,要求:月度的重点工作与目标,比周报更提炼一些。 # 2025年第11周 - 当前数仓慢sql反馈 - NTO技术架构评审、HiYES系统变更 - EBS SDS项目表变更(测试、生产) - EBS ppm应用访问数仓调整(生产数仓中 `ppm`.`SDI_ppm_technology` `ppm`.`SDI_ppm_project_info`没有任何分析用到这两张表,且两张表的数据量总共加在一起不到80条数据;另外放在数仓整个过程是通过两个同步作业完成的,还引入了延迟;用这两张表的业务逻辑也非常简) - 梳理EBS下的湖仓数据,发现有两个库没有在数据分析中使用过,ebs作为数据接口提供给其他应用使用,和ebs协商从湖仓中移除 # 2025年第10周 - CIM 邱云莹 测试环境 5个测试数据表入仓处理 - CIM 赵敏数据项目,新需求创建测试环境,数据入湖,编写作业入仓;生产环节数据导入到测试 - CIM 赵敏数据项目,同步优化:1.独立存储 2.减少一个同步(待赵敏调整后验证) - 参与SDS 代码交接相关事项,收回账号权限 - EBS的崔保康SDS测试环境开发支持,数据同步 - 其他业务实现相关支持 # 2025年第9周 - EBS BPM新增6个表入湖 - EBS OMS数据入湖 - EBS 采购数据,所有表重新调整过滤保密信息后重新入湖 - EBS调整采购入湖,影响了CIM赵敏的从湖入仓的同步,导致数据不一致,比对数据差异,告知CIM - NTO项目测试环境CSV数据入湖 - NTO项目两个物化视图膨胀(76亿、175亿),排查问题,告知用户问题点,用户修改 - 其他业务实现相关支持 # 2025年第8周 - BPM业务:Bpm_View_All_Workitem_Info入湖,编写入仓作业(按时间筛选) - 报销、采购、OA、HR业务表入湖,入仓,编写相关作业 - 支持ebs崔保康开发验证需求(数据同步、物化视图刷新、发现并修正sap引用) # 2025年第7周 - NTO项目入湖需求新增stage3入湖(测试环境和生产环境) - 调整OEE大表加工作业(大表连接、分组汇总) - 编写OEE的4个SUM表,从湖入仓 - 支持ebs sds项目测试环境验证变更(恢复测试环境、测试数据同步、物化视图刷新、发现并修正sap引用) - 其他业务实现相关支持 # 2025年第6周 - 编写OEE大表加工作业(初版):大表连接、分组汇总 - Sumrseqptime两个表入湖 - 处理EBS sap项目数据质量检查作业异常,调整后正常 - 假期运维处理AMC异常:1.异常字段值(调整作业特别处理,并告知用户)2.机台数据库无法访问(告知用户) - 其他业务实现相关支持 # 2025年第4周 - 编写作业完成FABALS的从湖入仓的实时推送 - FineBI获取 FABC.DM_DEFECT_TOTAL_1M 耗时较多,已告知 - 修正LINEC_FEOL_LOOP_STEP csv入湖,建表,作业测试 - 清理dolphin迁移前遗留的调度和数据源,修正sap数据比较作业 - 其他开发相关支持 # 2025年第3周 - 测试环境NTO入湖(新增10个表) - 升级测试环境数仓版本与生产保持一致 - FAC数据质量检查调度异常,已解决 - 协助EBS排查物化视图异常(sap.DWI_FINRPT_CONSUME_NUMBER_DETAIL_VIEW),已解决 - 其他开发相关支持 # 2025年第2周 - UAT环境:NTO入湖、处理指导 - 生产环境,测试环境数据同步ALLFAB.SDI_ALL_PRODUCT_TECH_VIEW - 跟进业务切换:FDL、Report、EBS sap等业务应用切换,暂无发现问题 - 其他开发相关支持 # 2025年第1周 - FAC amc mysql故障,作业恢复(告知owner,已解决) - ecoa入湖并编写入仓作业(8张),指导用户使用数仓 - 测试环境sap规范命名,为不影响开发,新增了一个命名规范的库方便开发随时切换 - 迁移旧数仓中amc历史数据到新数仓 - 其他开发相关支持
最新发布
03-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值