码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C语言数据结构算法之求出栈序列个数、判断出栈序列是否合法、求所有合法出栈序列、入栈次数、出栈次数、


    1. #include<stdio.h>
    2. #include<string.h>
    3. int zz=0;
    4. //出栈序列个数
    5. int Number(char *ch) {
    6. int len=strlen(ch),num=0,fz=1,fm=1;
    7. len=strlen(ch);
    8. for(int i=1,j=2*len; i<=len; i++,j--) {
    9. fm*=i;
    10. fz*=j;
    11. }
    12. return (fz/fm)/(len+1);
    13. }
    14. //判断出栈序列是否合法
    15. void Judge(char *push,char *pop) {
    16. int len=strlen(push);
    17. char sta[256],flag[512]="";
    18. int cur=-1,index=0;
    19. for(int i=0,j=0; i<len; i++) {
    20. sta[++cur]=push[i];
    21. flag[index++]='1';
    22. for(; cur!=-1&&sta[cur]==pop[j]; j++) {
    23. cur--;
    24. flag[index++]='0';
    25. }
    26. }
    27. if(cur==-1) printf("\n合法\t出入栈顺序:%s\n",flag);
    28. else printf("\n不合法\n");
    29. }
    30. //入栈次数
    31. int PushCount(char *seq) {
    32. int count=0;
    33. for(int i=0; i<strlen(seq); i++)
    34. if(seq[i]=='1') count++;
    35. return count;
    36. }
    37. //出栈次数
    38. int PopCount(char *seq) {
    39. int count=0;
    40. for(int i=0; i<strlen(seq); i++)
    41. if(seq[i]=='0') count++;
    42. return count;
    43. }
    44. //求所有合法出栈序列
    45. void AllSeq(int m,int n,char *seq,char *arr) {
    46. char sta[256]="";
    47. int index=0;
    48. if(2*m==n) {
    49. printf("\n%4d\t出入栈顺序:%s\t序列:",++zz,seq);
    50. for(int i=0,j=0; i<n; i++)
    51. if(seq[i]=='1') sta[index++]=arr[j++];
    52. else printf("%c ",sta[--index]);
    53. }
    54. if(PushCount(seq)<m) {
    55. seq[strlen(seq)]='1';
    56. AllSeq(m,n+1,seq,arr);
    57. }
    58. if(PushCount(seq)>PopCount(seq)&&(PushCount(seq)+PopCount(seq))<2*m) {
    59. seq[strlen(seq)]='0';
    60. AllSeq(m,n+1,seq,arr);
    61. }
    62. seq[strlen(seq)-1]=seq[strlen(seq)];
    63. }
    64. int main() {
    65. char push[256],pop[256];
    66. printf("入栈序列:");
    67. scanf("%s",push);
    68. getchar();
    69. printf("待判断出栈序列:");
    70. scanf("%s",pop);
    71. Judge(push,pop);
    72. printf("\n出栈序列个数:%d\n",Number(push));
    73. char seq[512]="";
    74. AllSeq(strlen(push),0,seq,push);
    75. return 0;
    76. }

     

     

  • 相关阅读:
    【每日一题Day34】LC808分汤 | 动态规划 记忆化搜索
    关于导出的Excel文件的本质
    基于Java+SpringBoot+Vue+uniapp微信小程序外卖系统设计和实现
    万年历查询易语言代码
    自动化测试与Jenkins持续集成实战
    TCO-PNB ester,1438415-89-4, 反式环辛烯-对硝基苯
    【Vue入门】语法 —— 事件处理器、自定义组件、组件通信
    医学图像标注终极指南
    Ascend910训练CSWin-Transformer失败
    全国产!全志T3+Logos FPGA核心板(4核ARM Cortex-A7)规格书
  • 原文地址:https://blog.csdn.net/weixin_63381305/article/details/127691040
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号