网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 其他技术区 > 算法与数据结构 >

顺序表练习题

时间:2025-11-07 22:18

人气:

作者:admin

标签:

导读:​1. 设顺序表中的元素递增有序,编写一个算法,将元素x插入顺序表L中的适当位置,以保持该顺序表的有序性。 void sortInsert(List *l,int x){ //假设表是有序的 if(l-gt;length==MAXSIZE) exit(1);//表...

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;
	}
} 
温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信