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

相关文章

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决