带头节点单链表操作

简介: #include #include #include using namespace std;typedef long long LL;typedef struct Node{ ...
#include <iostream>
#include <cstdio>
#include <cstdlib>
using namespace std;
typedef long long LL;
typedef struct Node{
    int data;
    struct Node *next;
}*List;
//头插法建立长为n的链表
void FrontCreateList(List &L,int n){
    List p;
    L=(Node*)malloc(sizeof(Node));
    L->next=NULL;
    for(int i=0;i<n;i++){
        p=(Node*)malloc(sizeof(Node));
        cin>>p->data;
        p->next=L->next;
        L->next=p;
    }
}
//尾插法建立长为n的链表
void EndCreateList(List &L,int n){
    List p,q;
    L=(Node*)malloc(sizeof(Node));
    L->next=NULL;
    for(int i=0;i<n;i++){
        p=(Node*)malloc(sizeof(Node));
        cin>>p->data;
        p->next=NULL;
        if(L->next==NULL)
            L->next=p;
        else
            q->next=p;
        q=p;
    }
}
//销毁链表
void Destroy(List &L){
    List p;
    while(L){
        p=L->next;
        free(L);
        L=p;
    }
    cout<<"OK"<<endl;
}
//清空链表
void Clear(List L){
    List p=L->next;
    L->next=NULL;
    Destroy(p);
}
//判断链表是否为空
bool IsEmpty(List L){
    if(L->next==NULL)
        return 1;
    else
        return 0;
}
//返回链表的长度
int Length(List L){
    int j=0;
    List p=L->next;
    while(p){
        j++;
        p=p->next;
    }
    return j;
}
//查找值是否存在
int GetData(List L,int i,int *e){
    int j=0;
    List p=L->next;
    while(p&&j<i){
        j++;
        p=p->next;
    }
    if(!p||i<1)
        return false;
    *e=p->data;
    return true;
}
//得到值的位置
int LocateData(List L,int e){
    int j=0;
    List p=L->next;
    while(p){
        j++;
        if(p->data==e)
            return j;
        p=p->next;
    }
    return false;
}
//在第i的位置插入e
void Insert(List L,int i,int e){
    int j=0;
    List p=L,q,s;
    while(p&&j<i-1){
        j++;
        p=p->next;
    }
    if(!p||i<1)
        exit(0);
    q=p->next;
    s=(Node *)malloc(sizeof(Node));
    if(!s)
        exit(-1);
    s->data=e;
    s->next=q;
    p->next=s;
}
//删除第i位置的节点,并用e返回
void Delete(List L,int i,int *e){
    int j=0;
    List p=L,q;
    while(p&&j<i-1){
        j++;
        p=p->next;
    }
    if(!p||i<1)
        exit(-1);
    q=p->next;
    *e=q->data;
    p->next=q->next;
    free(q);
}
//从头遍历链表
void Travel(List L){
    List p=L->next;
    while(p){
        cout<<p->data<<" ";
        p=p->next;
    }
    cout<<endl;
}
//测试
int main(){
    int n;
    cin>>n;
    List L;
    EndCreateList(L,n);
    Travel(L);
    cout<<Length(L)<<endl<<endl;


    int out,i;
    cin>>i;
    Delete(L,i,&out);
    cout<<out<<endl;
    Travel(L);
    cout<<Length(L)<<endl<<endl;


    int j,put;
    cin>>j>>put;
    Insert(L,j,put);
    Travel(L);
    cout<<Length(L)<<endl<<endl;

    int sear;
    cin>>sear;
    cout<<LocateData(L,sear)<<endl<<endl;

    cout<<IsEmpty(L)<<endl;
    Destroy(L);
    return 0;
}
目录
相关文章
|
2天前
|
数据采集 人工智能 安全
|
11天前
|
云安全 监控 安全
|
3天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1020 151
|
3天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
16天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1714 9
|
8天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
658 152
|
10天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
622 12
|
5天前
|
SQL 自然语言处理 调度
Agent Skills 的一次工程实践
**本文采用 Agent Skills 实现整体智能体**,开发框架采用 AgentScope,模型使用 **qwen3-max**。Agent Skills 是 Anthropic 新推出的一种有别于mcp server的一种开发方式,用于为 AI **引入可共享的专业技能**。经验封装到**可发现、可复用的能力单元**中,每个技能以文件夹形式存在,包含特定任务的指导性说明(SKILL.md 文件)、脚本代码和资源等 。大模型可以根据需要动态加载这些技能,从而扩展自身的功能。目前不少国内外的一些框架也开始支持此种的开发方式,详细介绍如下。
382 4