冲刺必会代码100题

会员:bjwj007 分享 更新时间: 2022-11-06 共 659 人阅读 投诉/版权异议
ET资源温馨提示:冲刺必会代码100题顺序表1、已知线性表(a1,a2,…,an)按顺序结构存储且每个元素为不相等的整数。设计把所有奇数移动到所有偶数前边的算法(要求时间最少,辅助空间最少)。【算法思
ET资源正文:

冲刺必会代码100题
顺序表
1、已知线性表(a1,a2,…,an)按顺序结构存储且每个元素为不相等的整数。设计把所
有奇数移动到所有偶数前边的算法(要求时间最少,辅助空间最少)。
【算法思想】:对于顺序表L,从左向右找到偶数L.data[i],从右向左找到奇数
L.data[j],将两者交换。循环这个过程直到i 大于j 为止。对应的算法如下:
void move(SqList &L)
{
int i = 0, j = L.length-1, k;
ElemType temp;
while(i <= j)
{
while(L.data[i]%2 == 1)
i++; //i 指向一个偶数
while(L.data[j]%2 == 0)
j--; //j 指向一个偶数
if(i < j)
{
temp = L.data[i]; //交换L.data[i]和L.data[j]
L.data[i] = L.data[j];
L.data[j] = temp;
}
}
}
本算法的时间复杂度为O(n),空间复杂度为O(1)。
2、设计一个高效算法,将顺序表L 中所有元素逆置,要求算法的空间复杂度为O(1)。
【算法思想】:扫描顺序表L 的前半部分元素,对于元素L.datai,将其与后半部分对
应元素L.data[L. length-i-1]进行交换。对应的算法如下:
void reverse(

冲刺必会代码100题
冲刺必会代码100题标题图片
本信息由 会员:bjwj007 整理发布。
本站声明:
1:本站不存储任何资源文件,敬请周知!本站所有资源仅供技术人员研究学习使用,如需商业使用请直接联系版权方获取授权!
2:本站信息若非特殊注明均为会员搜集发布,本站不对资源提供任何技术支持,请自行研究学习。
3:本站客服仅对站点使用提供咨询解答,不涉及任何资源内容信息。
4:本站不销售任何资源,我们仅提供技术交流分享服务。
5:如果此资源信息对你的权益造成困扰,请直接点击标题下的《投诉/版权异议》提交您的有效证明信息,我们会及时处理相关信息并且通知相关会员。

et资源
et资源 » 冲刺必会代码100题
标签:编程   代码   福利教程   优惠信息

答疑解惑FAQ

评论

发表评论