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

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui分页输入框回车与页面中@keyup.enter事件冲突解决

解决这个问题的思路只要判断事件源是哪个就好。el分页的回车触发事件是在按下时,抬起并不会再触发。而keyup.enter事件是在抬起时触发。 so,找不到分页的回车事件那就拿keyup.enter事件搞事情。只要判断这个抬起事件的$event中的锚点样式判断不等于分页特有的样式就可以了 @keyup.enter="allKeyup($event)" //页面上的//js中allKeyup(e

vue+elementui--$message提示框被dialog遮罩层挡住问题解决

最近碰到一个先执行this.$message提示内容,然后接着弹出dialog带遮罩层弹框。那么问题来了,message提示框会默认被dialog遮罩层挡住,现在就是要解决这个问题。 由于都是弹框,问题肯定是出在z-index比重问题。由于用$message方式是写在js中而不是写在html中所以不是很好直接去改样式。 不过好在message组件中提供了customClass 属性,我们可以利用