- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构》作业中的算法设计题参考答案
2.11
Status Insert_SqList(SqList va,int x)//把x插入递增有序表va中
{
if(va.length+1va.listsize) return ERROR;
va.length++;
for(i=va.length-1;va.elem[i]xi=0;i--)
va.elem[i+1]=va.elem[i];
va.elem[i+1]=x;
return OK;
}//Insert_SqList
2.13
LNode* Locate(LinkList L,int x)//链表上的元素查找,返回指针
{
for(p=L-next;pp-data!=x;p=p-next);
return p;
}//Locate
2.14
int Length(LinkList L)//求链表的长度
{
for(k=0,p=L;p-next;p=p-next,k++);
return k;
}//Length
2.15
void ListConcat(LinkList ha,LinkList hb,LinkList hc)//把链表hb接在ha后面形成链表hc
{
hc=ha;p=ha;
while(p-next) p=p-next;
p-next=hb-next;
free(hb);
}//ListConcat
2.22
void LinkList_reverse(Linklist L)//利用头插法实现链表的就地逆置;为简化算法,假设表长大于2
{
p=L-next;q=p-next;s=q-next;p-next=NULL;
while(s-next)
{
q-next=p;p=q;
q=s;s=s-next; //把L的元素逐个插入新表表头
}
q-next=p;s-next=q;L-next=s;
}//LinkList_reverse
分析:本算法的思想是,利用头插法,逐个地把L的当前元素q插入新的链表头部,p为新表的首元结点.
补充题:(是题2.14的扩充)
int number(LinkedNode head) //计算带头结点的单循环链表的结点个数
{
p=head;
i=0;
while(p-next != head)
{
i++;
p=p-next;
}
return i;
}
3.16
void Train_arrange(char *train)//这里用字符串train表示火车,H表示硬席,S表示软席
{
p=train;q=train;
InitStack(s);
while(*p)
{
if(*p==H) push(s,*p); //把H存入栈中
else *(q++)=*p; //把S调到前部
p++;
}
while(!StackEmpty(s))
{
pop(s,c);
*(q++)=c; //把H接在后部
}
}//Train_arrange
3.17
int IsReverse()//判断输入的字符串中前和后部分是否为逆串,是则返回1,否则返回0
{
InitStack(s);
while((e=getchar())!=)
push(s,e);
while((e=getchar())!=@)
{
if(StackEmpty(s)) return 0;
pop(s,c);
if(e!=c) return 0;
}
if(!StackEmpty(s)) return 0;
return 1;
}//IsReverse
3.18
Status Bracket_Test(char *str)//判别表达式中小括号是否匹配
{
count=0;
for(p=str;*p;p++)
{
if(*p==() count++;
else if(*p==)) count--;
if (count0) return ERROR;
}
if(count) return ERROR; //注意括号不匹配的两种情况
return OK;
}//Bracket_Test
3.19
Status AllBrackets_Test(char *str)//判别表达式中三种括号是否匹配
{
InitStack(s);
for(p=str;*p;p++)
{
if(*p==(||*p==[||*p=={) push(s,*p);
else if(*p==)||*p==]||*p==})
{
if(StackEmpty(s)) return ERROR;
pop(s,c);
if(*p==)
您可能关注的文档
- 《基础化学实验VI》(物化部分)课程教学大纲(化学专业)VI.doc
- 江西省赣州市兴国县将军中学2014届高三上学期第一次月考物理试题 无答案.doc
- 江西省赣州市兴国县将军中学2014届高三上学期第一次月考英语试题 无答案.doc
- 江西省赣州市兴国县将军中学2014届高三上学期第一次月考语文试题 含答案.doc
- 《基础化学实验V》(物化)课程教学大纲(应用化学专业).doc
- 江西省赣州市兴国县第三中学2015-2016学年高二下学期第一次月考化学试卷 无答案.doc
- 江西省赣州市兴国县第一中学2016届高三上学期第二次月考地理试题 含解析.doc
- 校园文化育人模式的工作报告.doc
- 《在线考试系统》总体设计报告.doc
- 江西省赣州市兴国县第三中学2015-2016学年高二下学期第一次月考物理试卷 无答案.doc
最近下载
- ICD-10消化系统疾病分类解析.pptx VIP
- 13G322-1~4钢筋混凝土过梁(2013年合订本).docx VIP
- 高考数学模拟卷.pdf VIP
- 数学人教版六年级下册《图形的认识与测量(一)》教学设计.doc VIP
- 钢结构工程施工质量控制ppt培训.pptx VIP
- 常州星河灯具报价清单.xls VIP
- 截止阀安装使用说明书-ArmstrongInternational.PDF VIP
- 人教版小学英语PEP五年级上册英译汉课文翻译(三起点).docx VIP
- 小升初暑假讲义17 《西游记》1 (教师版).doc VIP
- 2025年党员领导干部学习《党政机关厉行节约反对浪费条例》研讨会交流发言1.docx VIP
文档评论(0)