//判定是否回文#include#define maxsize 100typedef struct{ char base[maxsize]; char *top; }stack; int Huiwen(char *t_数据结构c语言版严蔚敏课后答案">
当前位置:   article > 正文

数据结构严蔚敏(c语言版)课后算法题答案-栈和队列_数据结构c语言版严蔚敏课后答案

数据结构c语言版严蔚敏课后答案

( 2 )回文是指正读反读均相同的字符序列, 如"abba ” 和“ abdba ” 均是回文, 但"good"
不是回文。试写一个算法判定给定的字符向量是否为回文。( 提示: 将一半字符入栈)

  1. #include<stdio.h> //判定是否回文
  2. #include<string.h>
  3. #define maxsize 100
  4. typedef struct
  5. {
  6. char base[maxsize];
  7. char *top;
  8. }stack;
  9. int Huiwen(char *t);
  10. int push(stack *s,char *t);
  11. int pop(stack *s);
  12. main()
  13. {
  14. int flag;
  15. char *str="assqssa";
  16. flag=Huiwen(str);
  17. if(flag==1) printf("是回文");
  18. else printf("不是回文");
  19. }
  20. int Huiwen(char *t)
  21. {
  22. char p;
  23. int len;
  24. stack s;
  25. len=strlen(t);
  26. s.top=s.base;
  27. for(int i=0;i<len/2;i++) { push(&s,t); t++; }
  28. while(s.top!=s.base)
  29. { p=pop(&s);
  30. if(len%2==0)
  31. { if(*t++!=p) return 0; }
  32. else
  33. { if(*++t!=p) return 0; }
  34. }
  35. return 1;
  36. }
  37. int push(stack *s,char *t)
  38. {
  39. if(s->top==s->base+maxsize) return 0;
  40. *s->top++=*t;
  41. }
  42. int pop(stack *s)
  43. {
  44. int e;
  45. if(s->top==s->base) return 0;
  46. e=*--s->top;
  47. return e;
  48. }

( 3 ) 设从键盘输入一整数的序列: al , a2 , a3,...,  an , 试编写算法实现: 用栈结构存储
输入的整数, 当ai!=1 时, 将进栈; 当ai=-1 时, 输出栈顶整数并出栈。算法应对异常情况( 入栈满等) 给出相应的信息。

  1. int comput(stack *s)
  2. {
  3. int i;
  4. while(s->top-s->base!=maxsize)//指针变量之间能相减,不能相加。
  5. {
  6. scanf("%d",&i);
  7. if(i==-1)
  8. {
  9. if(s->top==s->base) { printf("空栈"); return 0;}
  10. else
  11. while(s->top!=s->base) printf("%d ",*--s->top);
  12. return 0;
  13. }
  14. *s->top++=i;
  15. }
  16. printf("栈已满");
  17. return 0;
  18. }

( 5 ) 假设以丨和O 分别表示人栈和出栈操作。栈的初态和终态均为空, 人栈和出栈的操作序
列可表示为仅由丨和O 组成的序列, 称可以操作的序列为合法序列, 否则称为非法序列。写出一个算法, 判定所给的操作序列是否合法。若合法, 返回e , 否则返回false ( 假定被判定的操作序列己存人一维数组中)。

  1. #include<stdio.h>
  2. #include<string.h>
  3. #define true 1
  4. #define false 0
  5. int comput(char *s);
  6. main()
  7. {
  8. char *str="IIIOOIOO";
  9. int n;
  10. n=comput(str);
  11. if(n==1) printf("合法");
  12. else printf("不合法");
  13. }
  14. int comput(char *t) //法1
  15. {
  16. int sum=0;
  17. int a1=0,a2=0;
  18. int len;
  19. char *r=t;
  20. len=strlen(t);
  21. while(sum>=0&&t!=r+len)
  22. {
  23. if(*t=='I') {sum=sum+1; a1++; }
  24. else if (*t=='O') {sum=sum-1; a2++; }
  25. t++;
  26. }
  27. if(sum==0&&a1==a2) return true;
  28. else return false;
  29. }
  30. int comput(char a[]) //法2
  31. {
  32. int a1=0,a2=0;
  33. int len;
  34. len=strlen(a);
  35. int i=0;
  36. while(a1>=a2&&i<len) //或者while(a1>=a2&&a[i]!='\0')
  37. {
  38. if(a[i]=='I') a1++;
  39. else if (a[i]=='O') a2++;
  40. i++;
  41. }
  42. if(a1==a2) return true;
  43. else return false;
  44. }

( 10 ) 已知f 为单链表的表头指针, 链表中存储的都是整型数据, 试写出实现下列运算的递归
算法:
求链表中的最大整数;
求链表的结点个数;
求所有整数的平均值。

  1. int getmax(Link &f) //求链表最大整数
  2. {
  3. if(!f->next)
  4. return f->data;
  5. else
  6. {
  7. int max=getmax(f->next);
  8. if(max>=f->data) return max;
  9. else return f->data;
  10. }
  11. }
  12. int getlength(Link &f) //求链表结点个数
  13. {
  14. if(!f->next)
  15. return 1;
  16. return getlength(f->next)+1;
  17. }
  18. int getaverage(Link &f,int n) //求所有整数的平均数
  19. {
  20. if(!f->next)
  21. return f->data;
  22. else{
  23. double ave=getaverage(f->next,n-1);
  24. return (ave*(n-1)+f->data)/n;
  25. }
  26. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/运维做开发/article/detail/852808
推荐阅读
相关标签