当前位置: 首页 > news >正文

城市建设和房屋管理部门网站网站模板切换

城市建设和房屋管理部门网站,网站模板切换,做音乐分享的网站,备案 网站服务内容题目描述 现有一字符串仅由"(",")", "{","}", "[", "]"六种括号组成。若字符串满足以下条件之一, 则为无效字符串:任一类型的左右括号数量不相等 存在未按正确顺序(先左后右)闭合的括号输出…

题目描述

现有一字符串仅由"(",")", "{","}", "[", "]"六种括号组成。若字符串满足以下条件之一,

则为无效字符串:任一类型的左右括号数量不相等

存在未按正确顺序(先左后右)闭合的括号输出括号的最大嵌套深度,若字符串无效则输出0。

0<=字符串长度<=100000

输入描述

一个只包括(,’)’,’{‘,”}”,[,”]”的字符串

输出描述

整数,最大的括号深度

用例

一、问题分析

首先读题,仔细看描述中的内容,发现需求是

1.一个合法的括号匹配序列有以下定义:

(1)空串“”是一个合法的括号匹配序列

(2)如果“X”和“Y”都是合法的括号匹配序列,“XY”也是一个合法的括号匹配序列

(3)如果“X”是一个合法的括号匹配序列,那么“(X)”也是一个合法的括号匹配序列

(4)每个合法的括号序列都可以由以上规则生成。

2.对于一个合法的括号序列我们又有以下定义它的深度:

(1)空串“”的深度为0

(2)如果字符串“X”的深度是x,字符串“Y”的深度是y,那么字符串“XY”的深度为max(X,Y)

(3)如果“X”的深度是x,那么字符串“(X)”的深度是x+1

3.输入描述:输入包括一个合法的括号序列s,s长度length大于等于2小于等于50,序列中只包含括号(有两道题,一道题是只包括小括号,还有一道题是包括小括号中括号和大括号)

4.输出描述:输出一个正整数,即这个序列的深度

二、解题思路

1.先说只有小括号的情况(一定是合法的)

2.如果只有小括号(且输入合法),我们需要判断深度的话

3.定义一个整数int depth = 0;用来代表深度,定义一个整数int maxdepth = 0;

4.如果遇到左括号,depth增加1,然后如果depth大于maxdepth,maxdepth更新值

5.如果遇到右括号,depth减少1,

6.最后输出maxdepth就是最大深度了

#include <stdio.h>
#include <string.h>
int main() {char str[1000];scanf("%s", str);int depth = 0;int maxdepth = 0;int len = strlen(str);for(int i = 0; i < len; i++) {if(str[i] == '(') {depth++;} else if(str[i] == ')') {depth--;}if(depth > maxdepth) maxdepth++;}printf("%d\n", maxdepth);return 0;
}

1.然后再说有方括号大括号和括号三种括号的情况(并且有可能输入不合法)

2.如果输入不合法(比如左右括号不对称、未按正确顺序闭合)那么输出0

3.我们可以定义一个字符串数组char left[1000];用来记录遇到的括号

4.它的索引值为int idx = 0;我们遍历字符串char str[1000];,每遇到一个左括号,我们将这种类型的左括号放到栈顶,然后idx++

5.我们还需要在前面定义一个int maxdepth = 0;如果遇到的是左括号idx++之后,

6.比较idx和maxdepth的值,如果idx比较大,maxdepth更新值

7.如果我们遇到的是右括号,我们与左括号作比较,如果是同一类型的,那么我们idx--

8.如果是不同类型的,我们认为输入不合法,我们需要在前面定义一个bool valid = true;

9.如果遇到输入不合法的情况,那么我们valid = false;并且break;出循环

10.遍历完字符串以后,如果idx != 0;那么我们认为不合法valid = false;

11.最后,如果不合法,我们输出0,否则的话我们输出maxdepth的值

12.然后返回return 0;

三、具体步骤

使用的语言是C

#include <stdio.h>
#include <string.h>
#include <stdbool.h>
int main() {char str[1000];scanf("%s", str);char left[1000];int idx = 0;int maxdepth = 0;int len = strlen(str);bool valid = true;for (int i = 0; i < len; i++) {// printf("test i = %d\n", i);if (str[i] == '(' || str[i] == '[' || str[i] == '{') {// printf("遇到左括号\n");left[idx++] = str[i];if (idx > maxdepth) maxdepth = idx;// printf("idx = %d\n", idx);// printf("maxdepth = %d\n", maxdepth);} else if (str[i] == ')') {// printf("遇到)括号\n");if (left[idx - 1] == '(') idx--;else valid = false;} else if (str[i] == ']') {// printf("遇到]括号\n");if (left[idx - 1] == '[') idx--;else valid = false;} else if (str[i] == '}') {// printf("遇到}括号\n");if (left[idx - 1] == '{') idx--;else valid = false;} else {valid = false;}if (valid == false) break;}if (idx != 0) valid = false;if (valid) printf("%d\n", maxdepth);else printf("0\n");return 0;
}

http://www.yayakq.cn/news/527204/

相关文章:

  • 写资料的网站有哪些合肥到黄山旅游攻略
  • 服装厂做1688网站效果好不好html菜鸟教程视频
  • 临沂 网站推广ps切片工具做网站
  • 保定酒店网站制作做茶叶网站公司
  • 做网站和平台多少钱后台管理网站模板下载
  • 沭阳哪里可以做网站网站的发展历史
  • 网站权重怎么提升专业型网站和个人网站
  • 中小学智慧校园建设平台网站erp系统免费版下载
  • 制作类似网站软件商标制作logo设计
  • 网站开发费用报价表百度phcms wordpress
  • 加快网站收录燕莎做网站
  • 重庆模板网站建站网站建设 手机和pc
  • 宿迁做网站的公司外冈网站建设
  • name域名的网站西宁制作网站需要多少钱
  • 一个网站两个域名 seo湘潭网站
  • 有关网站建设的文章做旅游网站
  • wordpress修改之前发布文章的id石家庄seo代理
  • 南京浦口网站建设高端响应式网站
  • 高端网站设计报价二手车网站开发多少钱
  • 浏览器怎么设置不拦截任何网站企业名称怎么取
  • 仿163源码交易平台宽屏整站源码 网站模板交易平台源码如何速发布wordpress
  • 网站开发和浏览器兼容问题手机排行榜2021前十名性价比
  • 做网站不赚钱了网站开发基础与提高
  • 网站打开时的客户引导页品牌建设的最高境界是培育客户成为什么购买者
  • 网站开发设计总结及心得体会门户网站应该怎么做
  • 潮流资讯类网站建设策划网站做外链平台有哪些
  • 网站备案幕布尺寸服务器搭建网站用什么系统
  • 崂山网站建设友情链接是外链吗
  • 网站赚钱方法wordpress横向导航菜单主题
  • wordpress转移整站wordpress导航栏下拉菜单代码