教育资源为主的文档平台

当前位置: 查字典文档网> 所有文档分类> 高等教育> 工学> 数据结构第3章和滴4章参考答案

数据结构第3章和滴4章参考答案

上传者:贾耀梅
|
上传时间:2015-05-05
|
次下载

数据结构第3章和滴4章参考答案

数据结构第三章和第四章滴参考答案,有需要的额同学可以下载下来看看哦!

3.2 写出一个算法判定所给的操作序列是否合法。若合法,返回1,否则返回0

(假设被判定的操作序列已存入一维数组中)

Panduan(char *t)

{

InitStack(S);

while(*t)

{switch(*t)

{case ‘I’: Push(S,*t); break;

case ‘O’:if(!StackEmpty (S)) { Pop(S,e); break;} else return 0; } t++; }

if(!EmptyStack(T)) return 1;

return 0;

}

3.3 假设表达式中允许包含三种括号,圆括号,方括号和大括号,编写一个算法判断表达式中的括号是不是匹配

//入栈的操作

void push_stack(STACK *stack, char e)

{

stack->top++;

stack->ex[stack->top] = e;

}

//出栈的操作

bool pop_stack(STACK *stack, char *ch)

{

if(-1 == stack->top)

return false;

else

{

*ch = stack->ex[stack->top];

stack->top--;

}

return true;

}

//判断是不是匹配

//注意:此处有很多同学在判断右括号时,没有考虑栈顶元素,并要弹出栈顶元素 bool is_match(char *exp)

{

int i = 0;

char ch;

STACK *stack;

stack = init_stack();

数据结构第三章和第四章滴参考答案,有需要的额同学可以下载下来看看哦!

while(exp[i] != '\0') { if('('==exp[i] || '['==exp[i] || '{'==exp[i]) { push_stack(stack, exp[i]); } //如果是左括号直接进栈 else if(')'==exp[i] || ']'==exp[i] || '}'==exp[i]) { //,如果是右括号,考虑下面三种可能的匹配情况, switch(exp[i]) { case ')': if(pop_stack(stack, &ch)) { if(ch != '(') return false; } else return false; break; case ']': if(pop_stack(stack, &ch)) { if(ch != '[') return false; } else return false; break; case '}': if(pop_stack(stack, &ch)) { if(ch != '{') return false; } else return false; break; default:break; } } i++;

数据结构第三章和第四章滴参考答案,有需要的额同学可以下载下来看看哦!

}

if(stack->top==-1)

return true;

else

return false;

}

3.5编写一个算法,将一个环形队列(容量为n,元素下标从1到n)的元素倒置

解此题的思路是 将队列中的数据先转到栈中,然后再把栈中的数据转到另一个队列中,实现倒置。//注意:不是简单的首尾元素交换!因为交换意味着有元素要进队,而进队的操作与简单的交换操作是不同的!有很多同学是采取的交换方式

void traverse(QUEUE *queue1, QUEUE *queue2, STACK *stack)

{

queue1->front = (queue1->front)%10+1;

//将队列中的数出队放到栈中

while(queue1->front != queue1->rear)

{

stack->top++;

stack->c[stack->top] = queue1->ch[queue1->front];

queue1->front = (queue1->front)%10+1;

}

stack->top++;

stack->c[stack->top] = queue1->ch[queue1->front];

free(queue1);

//将元素出栈,放到队列中

queue2->rear = (queue2->rear)%10+1;

while(stack->top != -1)

{

queue2->ch[queue2->rear] = stack->c[stack->top];

stack->top--;

queue2->rear = (queue2->rear)%10+1;

}

}

4.1 采用顺序结构存储串,编写一个实现串通配符匹配的算法,pattern_index()其中的通配符只有“?”它可以和任意一字符匹配成功,例如pattern_index("?re", "there are")返回的结果是2

//字符串匹配

int pattern_index(STRING *t, STRING *s)

{

数据结构第三章和第四章滴参考答案,有需要的额同学可以下载下来看看哦!

int i = 0, j = 0; int n = 0; while(i<s->length) { if(s->string[i] == t->string[j] || t->string[j]==’?’) { i++; j++; } else {

i = i-j+1; //拉回到上一次匹配不成功的位置的下一处 j = 0; //模式串回到起始位置

} //注意:很多同学没有做这个动作!

//计算符合要求字串的个数

if(j>=t->length) //表明已经匹配成功

{

n++;

j = 0;

}

}

return n;

}

版权声明:此文档由查字典文档网用户提供,如用于商业用途请与作者联系,查字典文档网保持最终解释权!

下载文档

热门试卷

2016年四川省内江市中考化学试卷
广西钦州市高新区2017届高三11月月考政治试卷
浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
广西钦州市钦州港区2017届高三11月月考政治试卷
广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
广西钦州市高新区2016-2017学年高二11月月考政治试卷
广西钦州市高新区2016-2017学年高一11月月考政治试卷
山东省滨州市三校2017届第一学期阶段测试初三英语试题
四川省成都七中2017届高三一诊模拟考试文科综合试卷
2017届普通高等学校招生全国统一考试模拟试题(附答案)
重庆市永川中学高2017级上期12月月考语文试题
江西宜春三中2017届高三第一学期第二次月考文科综合试题
内蒙古赤峰二中2017届高三上学期第三次月考英语试题
2017年六年级(上)数学期末考试卷
2017人教版小学英语三年级上期末笔试题
江苏省常州西藏民族中学2016-2017学年九年级思想品德第一学期第二次阶段测试试卷
重庆市九龙坡区七校2016-2017学年上期八年级素质测查(二)语文学科试题卷
江苏省无锡市钱桥中学2016年12月八年级语文阶段性测试卷
江苏省无锡市钱桥中学2016-2017学年七年级英语12月阶段检测试卷
山东省邹城市第八中学2016-2017学年八年级12月物理第4章试题(无答案)
【人教版】河北省2015-2016学年度九年级上期末语文试题卷(附答案)
四川省简阳市阳安中学2016年12月高二月考英语试卷
四川省成都龙泉中学高三上学期2016年12月月考试题文科综合能力测试
安徽省滁州中学2016—2017学年度第一学期12月月考​高三英语试卷
山东省武城县第二中学2016.12高一年级上学期第二次月考历史试题(必修一第四、五单元)
福建省四地六校联考2016-2017学年上学期第三次月考高三化学试卷
甘肃省武威第二十三中学2016—2017学年度八年级第一学期12月月考生物试卷

网友关注视频

【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,广东省
二次函数求实际问题中的最值_第一课时(特等奖)(冀教版九年级下册)_T144339
沪教版八年级下次数学练习册21.4(2)无理方程P19
《空中课堂》二年级下册 数学第一单元第1课时
【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,辽宁省
苏科版数学八年级下册9.2《中心对称和中心对称图形》
飞翔英语—冀教版(三起)英语三年级下册Lesson 2 Cats and Dogs
外研版英语七年级下册module1unit3名词性物主代词讲解
苏教版二年级下册数学《认识东、南、西、北》
冀教版小学数学二年级下册第二单元《有余数除法的竖式计算》
第8课 对称剪纸_第一课时(二等奖)(沪书画版二年级上册)_T3784187
冀教版英语四年级下册第二课
外研版英语三起5年级下册(14版)Module3 Unit2
沪教版八年级下册数学练习册21.3(2)分式方程P15
【部编】人教版语文七年级下册《过松源晨炊漆公店(其五)》优质课教学视频+PPT课件+教案,辽宁省
青岛版教材五年级下册第四单元(走进军营——方向与位置)用数对确定位置(一等奖)
化学九年级下册全册同步 人教版 第25集 生活中常见的盐(二)
外研版英语三起6年级下册(14版)Module3 Unit1
沪教版牛津小学英语(深圳用) 五年级下册 Unit 10
北师大版数学四年级下册第三单元第四节街心广场
三年级英语单词记忆下册(沪教版)第一二单元复习
8.对剪花样_第一课时(二等奖)(冀美版二年级上册)_T515402
冀教版小学数学二年级下册1
沪教版八年级下册数学练习册21.4(1)无理方程P18
北师大版小学数学四年级下册第15课小数乘小数一
七年级下册外研版英语M8U2reading
沪教版牛津小学英语(深圳用)五年级下册 Unit 1
冀教版小学数学二年级下册第二单元《有余数除法的简单应用》
二年级下册数学第三课 搭一搭⚖⚖
外研版英语七年级下册module3 unit2第二课时