数据结构第1天作业 7月31日

news2024/11/15 10:53:44

 2.3按位置操作 

 1)按照位置插入数据

void Insert_seqlist_single(Seqlist* sq,int arr_sub,int num){
    if(sq->pos==N  ){             //判断顺序列表是否为满
        printf("error");
      return;
    }else if(arr_sub<0||arr_sub>sq->pos){
        printf("error");
     return;
    }else{
                for(int i=sq->pos-1;i>=arr_sub;i--){
                    sq->data[i+1]=sq->data[i];
                }
           sq->data[arr_sub]=num;
       
    }
    sq->pos++;
}

 2)按照位置删除数据

void Delete_seqlist_single(Seqlist* sq,int arr_sub){
    if(sq->pos==0){
        printf("error");
        return;
    }else if(arr_sub<0 || arr_sub>=sq->pos ){
        printf("error");
        return;
    }else{
        for(int i=arr_sub;i<sq->pos;i++){
            sq->data[i]=sq->data[i+1];
        }
    }
    sq->pos--;
}

 3)按照位置修改数据

void reorder_list(Seqlist* sq,int arr_sub,int num){
    if(sq->pos==0){
        printf("error\n");
    }else if(arr_sub<0 || arr_sub>=sq->pos){
        printf("error\n");
    }else {
        sq->data[arr_sub]=num;
    }
}

4)按照位置查找数据 

void Iterate_seqlist_single(Seqlist* sq,int arr_sub){
    if(sq->pos==0){
        printf("error");
    }else if(arr_sub<0 || arr_sub>=sq->pos){
        printf("error\n");
    }else {
        printf("%d\n",sq->data[arr_sub]);
    }
}

2.4按数据操作

 1)按照数据查找数据

int Iterate_seqlist_arr_sub(Seqlist* sq, int num) {
    for (int i = 0; i < sq->pos; i++) {
        if (sq->data[i] == num) {
            return i;
        }
    }
}

 2)按照数据修改数据

#include <stdio.h>
#include <stdlib.h>
#define N 10

typedef struct{
    int data[N];
    int pos;
}Seqlist;
//创建堆空间
Seqlist* establish(void){
    Seqlist* sq= malloc(sizeof (Seqlist));
    if(sq==NULL){
        printf("error");
    }
    sq->pos=0;
    return sq;
}
//堆空间释放
void free(void *ptr);
//顺序表(增:插入数据)
void Insert_seqlist(Seqlist* sq,int num){
    if(sq->pos==N){             //判断顺序列表是否为满
        printf("error");
    }else{
        sq->data[sq->pos]=num;
    }
    sq->pos++;
    //return ;
}
//查:顺序表 (遍历顺序表)
void Iterate_seqlist(Seqlist* sq){
    for(int i=0;i<sq->pos;i++){
        printf("%d ",sq->data[i]);
    }
    putchar(10);
}
void reorder_list_data(Seqlist* sq,int num1,int num2){
    if(sq->pos==0){
        printf("error");
    }else {
        for(int i=0;i<sq->pos;i++){
            if(sq->data[i]==num1){
                sq->data[i]=num2;
            }
        }
    }
}
int main(void){
    Seqlist* sq=establish();
    Insert_seqlist(sq,1);
    Insert_seqlist(sq,2);
    Insert_seqlist(sq,2);
    Insert_seqlist(sq,3);
    Insert_seqlist(sq,1);
    Iterate_seqlist(sq);
    reorder_list_data(sq,1,60);
    Iterate_seqlist(sq);
    free(sq);
    return 0;
}

 

  2.5删除顺序表

void Insert_seqlist(Seqlist* sq,int num){
    if(sq->pos==0){             //判断顺序列表是否为满
        printf("error");
    }else{
       sq->pos=0;
    }    
}

顺序表去重

删除重复数据(将先出现的数据与后面的数据对比,如果有重复的将后面的数据删除)
提示:可以直接使用按位置删除的函数。两层循环
顺序表中原有:1221134324534541
122134324534541
顺序表中存储:12345
提示:先找到重复数据的

位置,按位置删除。

#include <stdio.h>
#include <stdlib.h>
#define N 10

typedef struct{
    int data[N];
    int pos;
}Seqlist;
//创建堆空间
Seqlist* establish(void){
    Seqlist* sq= malloc(sizeof (Seqlist));
    if(sq==NULL){
        printf("error");
    }
    sq->pos=0;
    return sq;
}
//堆空间释放
void free(void *ptr);
//顺序表(增:插入数据)
void Insert_seqlist(Seqlist* sq,int num){
    if(sq->pos==N){             //判断顺序列表是否为满
        printf("error");
    }else{
        sq->data[sq->pos]=num;
    }
    sq->pos++;
    //return ;
}
//查:顺序表 (遍历顺序表)
void Iterate_seqlist(Seqlist* sq){
    for(int i=0;i<sq->pos;i++){
        printf("%d ",sq->data[i]);
    }
    putchar(10);
}
//按照位置删除
void Delete_seqlist_single(Seqlist* sq,int arr_sub){
    if(sq->pos==0){
        printf("error");
        return;
    }else if(arr_sub<0 || arr_sub>=sq->pos ){
        printf("error");
        return;
    }else{
        for(int i=arr_sub;i<sq->pos;i++){
            sq->data[i]=sq->data[i+1];
        }
    }
    sq->pos--;
}
//去重
void Deletion_duplicates(Seqlist* sq){
    for(int i=0;i<sq->pos;i++){
        for(int j=i+1;j<sq->pos;j++){
            if(sq->data[i]==sq->data[j]){
                Delete_seqlist_single(sq,j);
            }
        }
    }
}
int main(void){
    Seqlist* sq=establish();
    Insert_seqlist(sq,1);
    Insert_seqlist(sq,2);
    Insert_seqlist(sq,2);
    Insert_seqlist(sq,3);
    Insert_seqlist(sq,5);
    Insert_seqlist(sq,1);
    Insert_seqlist(sq,3);
    Insert_seqlist(sq,4);
    Insert_seqlist(sq,4);
    Insert_seqlist(sq,5);
    Deletion_duplicates(sq);
    Iterate_seqlist(sq);
    free(sq);
    return 0;
}


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1963946.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信小程序【五】好玩的点击展开弹框功能

弹出效果 步骤一、index.js步骤二、index.json步骤三、index.wxml步骤四、index.wxss 效果简述&#xff1a;恶搞的好玩点击效果&#xff0c;点击后展开 步骤一、index.js Page({data: {isPlaying: true,animationClass: music-icon,show_menu: false, // 菜单是否激活show_p…

异构算力的调度策略解析与实现

随着云计算、大数据和人工智能技术的飞速发展&#xff0c;异构算力调度成为了一个日益重要的课题。异构算力调度是指针对不同类型的计算资源&#xff08;如CPU、GPU、FPGA等&#xff09;进行合理分配与调度&#xff0c;以提高计算资源的利用率、降低功耗并加速任务执行。本文将…

浮点数的二进制表示

浮点数的二进制表示 浮点数在C/C中对应 float 和 double 类型&#xff0c;我们有必要知道浮点数在计算机中实际存储方式。 IEEE754规定&#xff1a; 单精度浮点数字长32位&#xff0c;尾数长度23&#xff0c;指数长度8,指数偏移量127&#xff1b;双精度浮点数字长64位&#xf…

Yarn UI 时间问题,相差8小时

位置 $HADOOP_HOME/share/hadoop/yarn/hadoop-yarn-common-2.6.1.jar 查看 jar tf hadoop-yarn-common-2.6.1.jar |grep yarn.dt.plugins.js webapps/static/yarn.dt.plugins.js 解压 jar -xvf hadoop-yarn-common-2.6.1.jar webapps/static/yarn.dt.plugins.js inflated: we…

mybatis-plus中出现Field ‘id‘ doesn‘t have a default value问题解决方法

问题分析&#xff1a; 出现这个原因&#xff0c;主要是因为mybatis-plus自身查询的特性&#xff0c;因为查询都是它自己内部设定好的参数&#xff0c;一般为了简便&#xff0c;都会默认自己底层的数据库对应的主键id字段是自增的&#xff0c;也就是mybatis-plus认为不需要id,每…

【Git】.gitignore全局配置与忽略匹配规则详解

设置全局配置 1&#xff09;在C:/Users/用户名/目录下创建.gitignore文件&#xff0c;在里面添加忽略规则。 如何创建 .gitignore 文件&#xff1f; 新建一个.txt文件&#xff0c;重命名&#xff08;包括后缀.txt&#xff09;为 .gitignore 即可。 2&#xff09;将.gitignore设…

Eagle平替?免费超强的素材管理神器!支持多级标签,满足素材快速收集!

作为设计师&#xff0c;你是不是下载了很多类型的素材资源&#xff0c;然而要每次使用的时候&#xff0c;还要通过文件夹一级一级去翻找&#xff0c;非常麻烦&#xff01;还好我找到了一款好用的素材管家神器—千鹿设计助手&#xff0c;如果你之前有用过Eagle或者BillFish的话&…

华为od机试真题:求字符串所有整数最小和(Python)

2024华为OD机试&#xff08;C卷D卷&#xff09;最新题库【超值优惠】Java/Python/C合集 题目描述 1.输入字符串s输出s中包含所有整数的最小和&#xff0c;说明&#xff1a;1字符串s只包含a~z,A~Z,,-&#xff0c; 2.合法的整数包括正整数&#xff0c;一个或者多个0-9组成&…

归并排序 python C C++ 图解 代码 及解析

一&#xff0c;概念及其介绍 归并排序&#xff08;Merge sort&#xff09;是建立在归并操作上的一种有效、稳定的排序算法&#xff0c;该算法是采用分治法(Divide and Conquer&#xff09;的一个非常典型的应用。将已有序的子序列合并&#xff0c;得到完全有序的序列&#xff…

大厂linux面试题攻略三之Shell编程

一、Shell编程文本截取类 1.有一个b.txt文本(内容如下)&#xff0c;要求将所有域名截取出来&#xff0c;并统计重复域名出现的次数 http://www.baidu.com/index.html https://www.atguigu. com/index.html http://www.sina.com.cn/1024.html …

二百四十八、Linux——删除/etc/.sudoers文件进程或修改/etc/.sudoers文件内容

一、目的 安装国产化数据库OceanBase的时候&#xff0c;需要创建用户&#xff0c;并在/etc/.sudoers文件中赋予用户root权限 二、删除/etc/.sudoers文件进程 1 报错 W10: Warning: Changing a readonly file E325: ATTENTION Found a swap file by the name "/etc/.su…

二叉树的性质证明

文章目录 二叉树的概念二叉树的性质1. 若规定根结点的层数为1&#xff0c;则一棵非空二叉树的第i层上最多有 2 i − 1 2^{i-1} 2i−1 个结点.2. 若规定根结点的层数为1&#xff0c;则深度为h的二叉树的最大结点数是 2 h − 1 2^h-1 2h−1.3. 对任何一棵二叉树, 如果度为0其叶结…

C++:函数模板与类模板详解

1.函数模板 在构造函数的时候&#xff0c;我们常常会考虑传入的参数的数据类型&#xff0c;比如我们写一个大小比较的函数mycmp(class1 a,class1 b)&#xff0c;则可以写出class1为int,float,double,string等各个种类的mycmp函数&#xff0c;这样会很麻烦&#xff0c;且当我们…

hot100-7-链表1

160相交链表 206反转链表 234回文链表 可以反转后半部分链表或者反转全部链表&#xff0c;然后对比输出 141环形链表 142环形链表2

大模型RAG入门及实践

前言 在大语言模型&#xff08;LLM&#xff09;飞速发展的今天&#xff0c;LLMs 正不断地充实和改进我们周边的各种工具和应用。如果说现在基于 LLM 最火热的应用技术是什么&#xff0c;检索增强生成&#xff08;RAG&#xff0c;Retrieval Augmented Generation&#xff09;技…

【JVM】JVM的组成与执行流程

JVM 由哪些部分组成&#xff0c;运行流程是什么&#xff1f; JVM 是什么 Java Virtual Machine Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 好处&#xff1a; 一次编写&#xff0c;到处运行自动内存管理&#xff0c;垃圾回收机制 JVM的组成 我…

redis集群 高可用

目录 主从复制 主从复制的流程 部署主从复制 步骤 哨兵模式 数据流向 步骤 故障恢复 cluster集群 数据流向 步骤 redis集群的三种模式&#xff1a; 主从复制 奇数台 1主2从 哨兵模式 奇数台 1主2从 cluster 集群 6 台 主从复制 原理&#xff1a;主可以…

(四)延时任务篇——redisson实现延迟任务实战

前言 上一节内容中介绍了如何使用redis的zset结构实现延迟任务的实战内容&#xff0c;从使用角度来说还是略显繁琐&#xff0c;而且定时任务的方式扫描redis获取过去的任务也会存在任务空转的问题。在此基础上&#xff0c;我们可以使用redisson的阻塞队列&#xff0c;完成延迟…

探索 Python 的新世界:funcy 库的神奇之旅

文章目录 探索 Python 的新世界&#xff1a;funcy 库的神奇之旅背景&#xff1a;为何 funcy 如此迷人&#xff1f;简介&#xff1a;funcy 库是什么&#xff1f;安装&#xff1a;如何将 funcy 纳入你的项目&#xff1f;功能&#xff1a;funcy 的五大法宝应用&#xff1a;funcy 在…