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

顺序表练习题

1. 设顺序表中的元素递增有序,编写一个算法,将元素x插入顺序表L中的适当位置,以保持该顺序表的有序性。

void sortInsert(List *l,int x){//假设表是有序的if(l->length==MAXSIZE)exit(1);//表已满,无法插入for(int i=0;i<l->length;i++){if(l->data[i]>=x){ //合适的位置//执行后移操作for(int j=l->length-1; j>i;j--){l->data[j+1]=l->data[j];}//插入l->data[i]=x;l->length++;return; //跳出}}//如果循环结束了都还没有插入,则代表它比所有元素都要大,位置放在最后一个l->data[l->length++]=x;
}

​ 优化版:

void sortInsert(List *l, int x) {if (l->length == MAXSIZE) {fprintf(stderr, "错误:表已满,无法插入!\n");exit(EXIT_FAILURE);}int i;// 找插入位置(从后往前找更高效)for (i = l->length - 1; i >= 0 && l->data[i] > x; i--) {l->data[i + 1] = l->data[i];}// 插入到合适位置l->data[i + 1] = x;l->length++;
}

2. 编写算法实现顺序表的的就地逆置。

void ReverseList(List *l){if(l->length==0)return;for(int i=0,j=l->length-1; i<j;i++,j--){int temp = l->data[i];l->data[i]=l->data[j];l->data[j]=temp;}
} 
http://www.jsqmd.com/news/34640/

相关文章:

  • 关于一种计算递归次数题的思路
  • 前端框架深度解析:Vue 从入门到实战,掌握渐进式开发核心 - 实践
  • CF2162G
  • 题解:lo6878 生不逢时
  • 【UEGamePlay】- 3C篇(三) : 角色 (二)
  • stapter WP笔记
  • 【51单片机】【protues仿真】基于51单片机全自动洗衣机系统 - 教程
  • 定金单专题
  • 练习上传
  • uniapp修改原生导航栏样式、加图标、加文字、加点击事件 - 详解
  • CITP——更适合约束接口的CRTP变式 - CLimber
  • 函数的可变参数传参
  • P12366 [蓝桥杯 2022 省 Python B] 数位排序
  • 重组蛋白表达技术|HEK293细胞蛋白表达|高效重组蛋白生产服务
  • CJI8运行查询没有数据
  • Para 集训
  • RK3576在智能工程机械中的应用|三屏八摄AI视觉解决方案
  • 贪心,排序,二分,分治
  • python01
  • AI Compass前沿速览:Cursor 2.0、Firefly Image5、Agent HQ 、LongCat-Video、Kimi-k2 Thinking
  • 25.11.7联考题解
  • 浅谈dp中的最优化、计数问题
  • CF715B
  • [NOIP 2001 提高组] 一元三次方程求解
  • EPnP算法学习随笔
  • 毒盘未转存仅支持在线观看30s
  • P14322 「ALFR Round 11」E 空崎ヒナ 小结
  • AI元人文:理论自省与客观评估
  • [Element Plus 组件库的官方 API 参考文档] 的部分内容的解释
  • ZK笔记