- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与算法 作业参考答案.doc
作业参考答案
一、(带头结点)多项式乘法 C = A×B:
void PolyAdd ( list C, list R) // R 为单个结点
{
p=C;
while ((!p-next) (p-next-expR-exp)) p=p-next;
if ((p-next) || (p-next-expR-exp))
{ R-next=p-next; p-next=R; } else
{ p-next-inf += R-inf; delete R;
if ( ! p-next-inf )
{ R=p-next; p-next=R-next; delete R; }
}
}
void PolyMul ( list A, list B, list C )
{
C=new struct node; C-next=NULL; q=B-next;
While ( q )
{
p=A-next;
while ( p )
{
r = new struct node; r-exp = p-exp + q-exp;
r-inf = p- inf * q-inf; PolyAdd(C, r);
p=p-next;
}
q=q-next;
}
}
二、梵塔的移动次数:
已知移动次数迭代公式为: M ( n ) = 2M ( n-1 ) + 1
初值为: M ( 0 ) = 0
则: M ( n ) = 2 ( 2M ( n-2 ) + 1 ) + 1
= 4M ( n-2 ) + 3
= 8M ( n-3 ) + 7
= 2iM ( n-i ) + 2i – 1
若n=i , 则M ( n-n ) = 0, 故:M ( n ) = 2nM ( n-n ) + 2n – 1
= 2n – 1
所以,梵塔的移动次数为2n – 1次。
三、简化的背包问题:
void Pack ( int m, int i, int t ) // 初始值为: 1 1 t
{
for ( k=i; k=n; k++ )
{
solution[m] = weight[k];
if ( t == weight[k] )
{
for ( j=1; j=m; j++ ) coutsolution[j]; coutendl;
} else if ( t weight[k] ) Pack ( m+1, k+1, t - weight[k] );
}
}
四、判断括号是否配对:
int Correct ( string s )
{
Inistack(Q);
for ( i=0; s[i] == ‘=’; i++ ) // 表达式以‘=’结束
{
switch ( s[i] )
{
case ‘(’:
case ‘[’:
case ‘{’:
Push ( Q, s[ i ] ); break;
case ‘)’:
case ‘]’:
case ‘}’:
if ( Empty(Q)) return 0; t=Pop(Q);
if ( ! Matching( t, s[i] )) return 0;
}
}
if ( ! Empty(Q) ) return 0;
return 1;
}
五、堆栈可能的输出:
1243 1324 1342 1423 1432
2143 2314 2341 2413 2431
3124 3142 3214 3241 3412 3421
4132 4213 4231 4312 4321
六、用两个堆栈实现一个队列:
int FullQ ( )
{
if (Full (S1) ! Empty (S2)) return 1; return 0;
}
int EmptyQ ( )
{
if ( Empty (S1) Empty (S2)) return 1; return 0;
}
void Enqueue ( elemtype x)
{
if (Full(S1)) i
您可能关注的文档
最近下载
- 成立能源管理体系建设工作领导小组通知.docx
- 2022年鹏程杯5年级数学竞赛真题+解析.pdf
- 牛津译林版(2024)英语七年级上册第一学期期末测试卷(含答案,无音频,含听力原文).pdf VIP
- 实施弹性退休制度暂行办法解读课件PPT.pptx
- 期末复习测试题一(九年级物理).doc VIP
- 2024年农村信用社高管考试试题一.doc
- 2024-2025学年河南省郑州市金水区四年级(上)期末英语试卷(全解析版).docx
- 喜欢新老师(教学设计)-2024-2025学年岭美版(2024)美术一年级上册.docx VIP
- 2024年银行考试-授信业务资格笔试参考题库含答案.docx
- 幼儿园:四个月观察记录.doc
文档评论(0)