当前位置: 首页 > news >正文

自己怎么做团购网站首页泉州建设系统培训中心网站

自己怎么做团购网站首页,泉州建设系统培训中心网站,邢台企业网站建设,做婚庆网站图片下载文章目录线性表顺序表接口实现尾插尾删头插头删指定位置插入指定位置删除练习线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列…

文章目录

  • 线性表
    • 顺序表
      • 接口实现
        • 尾插
        • 尾删
        • 头插
        • 头删
        • 指定位置插入
        • 指定位置删除
      • 练习

线性表

线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串…
线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储

顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改

(顺序表就是数组,但是是在数组的基础上,另外还要求数据是从头开始存储 ,并且数据是连续存储的,不能跳跃间隔)

顺序表一般可以分为:

  • 静态顺序表:使用定长数组存储元素
  • 动态顺序表:使用动态开辟的数组存储

接口实现

尾插

 typedef struct SeqList
{SLDaTaType * a;int size; // 数组中存了多少个数int capacity; //数组实际容量个数
}SL;void SeqListPushBack(SL* ps, SLDaTaType x)   //尾插
{assert(ps);//空间不足则扩容 if (ps->capacity == ps->size){int newcapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;   // 若空间为0  就放4个字节  , 否则capacity *2  SLDaTaType * tmp  = ( SLDaTaType* )realloc(ps->a, newcapacity * sizeof(SLDaTaType));if (tmp == NULL) //开辟失败{printf("realloc fail \n");exit(-1);  }ps->a = tmp;ps->capacity = newcapacity;}ps->a[ps->size] = x;  // 空间足够 ps->size++;
} 

void SeqListDestory(SL* ps) //销毁 ,防止内存泄露
{assert(ps);free(ps->a);ps->a = NULL; ps->size = ps->capacity = 0;
}

尾删

void SeqListPopBack(SL* ps)// 尾删
{assert(ps);// ps->a[ps->size - 1] = 0;assert(ps->size > 0);ps->size--;  
}

头插

最后一个数向后挪动
在这里插入图片描述

void SeqListPushFront(SL* ps, SLDaTaType x) // 头插
{assert(ps);// 挪动 int end = ps->size - 1;while (end >= 0){ps->a[end + 1] = ps->a[end];end--;}ps->a[0] = x;ps->size++;
}

头删

void SeqListPopFront(SL* ps) // 头删
{assert(ps);assert(ps->size > 0);//挪动数据int begin =1 ;while (begin<=ps->size){ps->a[begin - 1] = ps->a[begin];begin++;}ps->size--;
}

在这里插入图片描述

找到了返回x位置下标 若没有找到返回-1

int SeqListFind(SL* ps, SLDaTaType  x)
{assert(ps);for (int i = 0; i < ps->size; i++){if (ps->a[i] == x){return i;}}return -1; 
}

指定位置插入

void SeqListInsert(SL* ps, int pos, SLDaTaType x) // 指定位置插入
{assert(ps);assert(pos >=0 && pos <= ps->size);int end = ps->size -1 ;SeqListCheckCapacity(ps); //防止后面空间不足 挪动的时候越界访问while (end >= pos){//挪动 ps->a[end + 1] = ps->a[end];end--;}//插入数据ps->a[pos] = x;ps->size++;
}

在这里插入图片描述

指定位置删除

void SeqListErase(SL* ps, int pos) // 指定位置删除
{assert(ps);assert(pos >= 0 && pos < ps->size);int begin = pos + 1;while (begin < ps->size){ps->a[begin - 1] = ps->a[begin];begin++;}ps->size--;
}

在这里插入图片描述

练习

https://leetcode.cn/problems/remove-element/

思路一 : 找到所有的val ,一次挪动数据覆盖删除
时间复杂度最坏的情况是数组中绝大部分值是val甚至全部是val

假设数组中有N个数据 第一个数据是val ,这时候需要挪动N-1 个元素 ,
第二个数据是val ,得挪动N-2个元素
依次类推 第n个数据是val ,得挪动N-n
不难发现是一个等差数列 ,时间复杂度为O(N^2)

思路二:

依次遍历整个数组 ,把不是val 得值放到tmp 数组中 ,再把tmp数组得值拷贝到nums数组中 ,这样我们将时间复杂度优化到 O(N) ,但是空间复杂度 为O(N)
在这里插入图片描述

思路三 src去找nums 数组中不是val 的值 , 放到dst 指向的位置中 ,再++src ++dst
这样时间复杂度是O(N) ,空间复杂度是O(1)

在这里插入图片描述

int removeElement(int* nums, int numsSize, int val)
{int src = 0;int dst =0 ;while (src < numsSize ){if( nums[src]!=val ){nums[dst] = nums[src];src++ ;dst ++ ;    }else {src++;}}return dst;
}

https://leetcode.cn/problems/remove-duplicates-from-sorted-array/
在这里插入图片描述


在这里插入图片描述

int removeDuplicates(int* nums, int numsSize)
{if (numsSize==0  ){return 0 ;}int j =1;int i = 0;int dst = 0 ;// j 没有越界 while( j<numsSize){// 判断 i和j是否相等 不相等就继续往下找if(nums[i] ==nums[j]){j++ ;}else   // 不相等就把 nums[dst]=nums[i]{nums[dst]=nums[i];i=j;dst++;j++;}}//j越界nums[dst]=nums[i];++dst;return dst ; // 返回dst的下标
}

如果你觉得这篇文章对你有帮助,不妨动动手指给点赞收藏加转发,给鄃鳕一个大大的关注
你们的每一次支持都将转化为我前进的动力!!!

http://www.yayakq.cn/news/24383/

相关文章:

  • 广州致格广告有限公司网站建设旅游网站缺点
  • 网站开发合同违约责任网络运营可以自学吗
  • 那个网站做外贸最好wordpress替换表情变小
  • 做网站怎么建文件夹织梦和wordpress哪个好
  • 网站维护具体做啥如何对现有的网站改版
  • 做网站找模板去哪好建设网站要多久的时间
  • 大一学生做的网站网站优化北京
  • IT男网站建设网站怎么不要钱自己做
  • 广元建设机械网站创意设计与制作
  • 网站后台管理的超链接怎么做常见软件开发模型有哪些
  • 装修网站是怎么建设的网站工程师培训学校
  • 扬州外贸网站seo何炅做的网站广告
  • 中国建设网站用户名wordpress 三栏主题
  • 做网站怎么申请域名能通过淘宝网站做淘宝客吗
  • 网站流量怎么提升个人电商网站建设范例
  • 企业网站模板源码资源下载百度搜索优化费用
  • 玉林专业网站建设wordpress 电话插件
  • 网站建设专题页面专业找图片的网站
  • 菜鸟学做网站的步骤网站模板大全下载
  • wordpress 做大型网站短视频运营公司网站建设
  • 用jsp做校园网站法律建设企业网站
  • 付费抽奖网站怎么做绿色推广盒子app
  • ppt的网站导航栏怎么做的asp网站模板下载
  • 怎么开发软件挣钱青岛网站建设方案优化
  • 网站是怎么优化的网站前台后台哪个好
  • 常山网站建设怎么用PHP做网站留言板
  • 在线做试卷的网站平面设计到题目
  • 厦门建站最新消息上传文档网站开发
  • 深圳 网站建设建设部网站城市规划资质标准
  • 南京建设行政主管部门网站网站建设_制作_设计