c语言解决特殊字符对齐问题

2024-05-25 04:18

本文主要是介绍c语言解决特殊字符对齐问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题如下:

给出一个字符串,包含(){}[]<>四种字符,试给出一算法,实现字符串格式检查
检查成对的字符是否位置正确有效
eg: <{}>()有效

asd<2{w142y6}gss>ss(s)d有效
<{>}[]无效\

解决思路:

基本就是遍历整个字符串依次判断,这里提供一种技巧,就是用栈的方法。

所有的左括号都直接进栈,然后右括号就判断栈定是不是跟当前右括号匹配的,如果匹配就两个都出栈,如果不匹配就继续遍历,最后栈是空的就说明是符合要求的。如果有不明白可以自己画图思考。这里简单举例说明。

假如有字符串" < [ ] > " ,有空增栈一个。首先开始遍历字符串,查到第一个特殊符号' < '把他入栈,然后继续遍历查到第二个特殊符号' [ '也入栈,然后第三个特殊符号' ] ',根据栈的特性,此时栈顶为' [ '判断它是否和‘ ] ’对应,如果对应则出栈,否则不进行操作。这里是对应的就出栈了,同样的道理遍历到最后一个元素时,也会有出栈操作,最终这个栈为空,说明所有特殊符号的位置是符合要求的。

而对于字符串" [ { ] } ",我们可知在' [ '和' { '相继入栈后,第三个元素由于栈顶元素和它不匹配,不能出栈,最终栈内会剩一个' [ ',此时栈不为空,所以这个字符串的特殊符号位置就不符号要求。接下来附上全部代码

/***@filename align.c*@author   haohaibo*@data     2017/8/12*@brief	 字符中的特殊符号对齐问题*/#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define N 100typedef char	datatype_t;
typedef struct node{datatype_t data;struct node *Next;	
}linkstack_t;/***@brief 创建一个空的栈*/
linkstack_t *linkstack_creat()
{linkstack_t *header;header=(linkstack_t *)malloc(sizeof(linkstack_t));if(NULL==header){printf(__FUNCTION__);printf("ERROR in line %d",__LINE__);return (linkstack_t *)-1;}header->Next=NULL;return header;
}
/***@brief 检查栈是否为空*/
int linkstack_empty(linkstack_t *header)
{if(header->Next==NULL){//printf("linkstack empty!\n");return 1;}return 0;
}/***@brief 入栈*/
int linkstack_insert(linkstack_t *header,datatype_t value)
{linkstack_t *insert;insert=(linkstack_t *)malloc(sizeof(linkstack_t));if(NULL==insert){printf(__FUNCTION__);printf("ERROR in line %d",__LINE__);return -1;}insert->data=value;insert->Next=header->Next;header->Next=insert;return 0;
}/***@brief 出栈*/
datatype_t linkstack_out(linkstack_t *header)
{if(linkstack_empty(header))return;datatype_t value;linkstack_t *temp=header->Next;value=temp->data;header->Next=temp->Next;free(temp);temp==NULL;return value;
}datatype_t linkstack_peek(linkstack_t *header)
{if(linkstack_empty(header))return;return header->Next->data;
}/***@brief 打印栈的所有数据*/
int linkstack_show(linkstack_t *header)
{while(header->Next!=NULL){header=header->Next;printf("data is %c\n",header->data);}
}/***@brief 检查特殊符号是否对齐*/	
int check_str(char *str)
{		linkstack_t *s1;s1=(linkstack_t *)malloc(sizeof(linkstack_t));char str_char;while(*str){str_char = *str;if(str_char== '<'||str_char == '['||str_char == '{'||str_char == '(')linkstack_insert(s1,str_char);else if(str_char == '>'||str_char == ']'||str_char == '}'||str_char == ')'){switch(str_char){case '>':if(linkstack_peek(s1)=='<'){linkstack_out(s1);}break;case '}':if(linkstack_peek(s1)=='{')linkstack_out(s1);break;case ']':if(linkstack_peek(s1)=='[')linkstack_out(s1);break;case ')':if(linkstack_peek(s1)=='(')linkstack_out(s1);break;default:break;			}				}	str++;}return linkstack_empty(s1);
}	int main(void)
{char str[64]="";puts("输入字符串特殊符号必须成对输入:");scanf("%s",str);if(check_str(str)){puts("正确对齐!!");}else{puts("错误对齐!!");}}




这篇关于c语言解决特殊字符对齐问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1000454

相关文章

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在