【3D技术宅公社】XR数字艺术论坛  XR技术讨论 XR互动电影 定格动画

 找回密码
 立即注册

QQ登录

只需一步,快速开始

调查问卷
论坛即将给大家带来全新的技术服务,面向三围图形学、游戏、动画的全新服务论坛升级为UTF8版本后,中文用户名和用户密码中有中文的都无法登陆,请发邮件到324007255(at)QQ.com联系手动修改密码

3D技术论坛将以计算机图形学为核心,面向教育 推出国内的三维教育引擎该项目在持续研发当中,感谢大家的关注。

查看: 1981|回复: 1

[算法/加密解密] 插入排序之四 表插入排序

[复制链接]
发表于 2013-8-8 13:58:29 | 显示全部楼层 |阅读模式
  若希望在排序过程中不移动记录,只有改变存储结构,进行表插入排序。存储结构定义如下:
  1. #define SIZE 100        //静态链表容量
  2. typedef struct  
  3. {
  4.     string rc;        //记录项
  5.     int next;        //指针项
  6. }SLNode;                //表结点类型
  7. typedef struct
  8. {
  9.     SLNode r[SIZE];    //0号单元为表头结点
  10.     int length;        //链表当前长度
  11. }SLinkListType;        //静态链表类型
复制代码
为了方便插入,设数组中下标为“0”的分量为表头结点,并令表头结点记录的关键字取最大整数MAXINT。则表插入排序的过程描述如下:首先将静态链表中数组下标为“1”的分量(结点)和表头结点构成一个循环链表,然后依次将下标为“2”至“n”的分量(结点)按记录关键字非递减有序插入到循环链表中。时间复杂度为O(n^2)理解:和直接插入排序同样的处理方式,只不过不需要移动记录,只要改变next域。表插入排序的结果只是求得一个有序链表,所以只能进行顺序查找。
算法同直接插入排序。

发表于 2014-12-13 14:03:23 | 显示全部楼层
好好好好好好好好好好
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|3D数字艺术论坛 ( 沪ICP备14023054号 )

GMT+8, 2025-2-6 00:54

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表