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

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据