登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
业界区
›
科技
›
判断字符串是否合理
判断字符串是否合理
[ 复制链接 ]
辗振
2025-6-7 16:17:20
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
通过键盘输入一个包括 '(' 和 ')' 的字符串string ,判断字符串是否有效。要求设计算法实现检查字符串是否有效,有效的字符串需满足以下条件:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。
/***************************************************************************
*function:创建一个顺序栈,判断字符串是否合理
*author:jindouliu2024@163.com
*date:2025.4.4
*
* Copyright (c) 2024-2025 jindouliu2024@163.com All right Reserved
* ***************************************************************************/
#include<stdio.h>
#include <stdbool.h>
#include <stdlib.h>
//指的是顺序表中的元素的数据类型,可以根据需要进行修改
typedef int DataType_t;
//构造记录顺序栈SequenceStack各项参数(顺序栈的栈底地址 + 顺序栈的容量 + 顺序栈中最后有效元素的下标)的结构体
typedef struct SequenceStack
{
DataType_t * Bottom; //记录顺序栈的栈底
unsigned int Size; //记录顺序栈的容量
int Last; //顺序栈中最后元素的下标
}SeqStack_t;
//创建顺序栈并对顺序栈进行初始化
SeqStack_t * SeqStack_Create(unsigned int size)
{
//1.利用calloc为顺序栈的管理结构体申请一块堆内存
SeqStack_t *Manager = (SeqStack_t *)calloc(1,sizeof(SeqStack_t));
if(NULL == Manager)
{
perror("calloc memory for manager is failed");
exit(-1); //程序异常终止
}
//2.利用calloc为所有元素申请堆内存
Manager->Bottom = (DataType_t *)calloc(size,sizeof(DataType_t));
if (NULL == Manager->Bottom)
{
perror("calloc memory for element is failed");
free(Manager);
exit(-1); //程序异常终止
}
//3.对管理顺序栈的结构体进行初始化(元素容量 + 最后元素下标)
Manager->Size = size; //对顺序栈中的容量进行初始化
Manager->Last = -1; //由于顺序栈为空,则最后元素下标初值为-1
return Manager;
}
//向顺序栈加入元素
bool SeqStack_Add(SeqStack_t *Manager, DataType_t Data)
{
//1.判断顺序表是否已满
if ( SeqStack_IsFull(Manager) )
{
printf("SeqStack is Full!\n");
return false;
}
//2.如果顺序栈有空闲空间,则把新元素添加到顺序栈
Manager->Bottom[++Manager->Last] = Data;
return true;
}
//判断顺序栈是否为空
bool SeqStack_IsEmpty(SeqStack_t *Manager)
{
return (-1 == Manager->Last) ? true : false;
}
DataType_t SeqStack_Del(SeqStack_t *Manager)
{
// 不为空时
if(Manager->Last >=0){
return Manager->Bottom[Manager->Last--];
}
}
bool Is_valid_Str(SeqStack_t *Manager,char *str)
{
while(*str != '\0'){
if(*str == '('){
SeqStack_Add(Manager,1);
}
else if(*str == ')') {
//判断栈是否为空
if(SeqStack_IsEmpty(Manager) == true){
return false;
}
SeqStack_Del(Manager);
}
str++;
}
//判断栈是否为空
if(!SeqStack_IsEmpty(Manager)){
return false;
}
return true;
}
int main()
{
//创建一个空的顺序栈
SeqStack_t *qlist=SeqStack_Create(100);
char str[100];
//输入一个字符串
printf("请输入一个字符串:");
scanf("%s",str);
//调用函数进行判断
if(Is_valid_Str(qlist,str) == false){
printf("this is not valid\n");
}
else{
printf("this is valid\n");
}
return 0;
}
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
判断
字符串
是否
合理
相关帖子
字符串哈希
射线法判断一个坐标点(经纬度)是否在一个多边形区域内部
[20260228]如何实现字符串拆分输出数字序列.txt
kmp算法:我们所忽略的字符串匹配本质
S001 【模板】从前缀函数到KMP应用 字符串匹配 字符串周期
S002 字符串构造 最长相等真前后缀 CF1029A
普通人是否需要接触 OpenClaw?我的答案是:值得,但要注意安全风险
空论是否有思想史意义?
MySQL不推荐使用UUID等字符串做主键
Fastjson枚举反序列化:当字符串不是枚举常量名时,会发生什么?
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
字符串哈希
9
178
辗振
2026-02-08
业界
射线法判断一个坐标点(经纬度)是否在一个多边形区域内部
5
29
翁真如
2026-02-11
安全
[20260228]如何实现字符串拆分输出数字序列.txt
1
507
系味
2026-03-01
业界
kmp算法:我们所忽略的字符串匹配本质
2
810
云卦逾
2026-03-02
业界
S001 【模板】从前缀函数到KMP应用 字符串匹配 字符串周期
4
284
钦娅芬
2026-03-04
安全
S002 字符串构造 最长相等真前后缀 CF1029A
1
280
挫莉虻
2026-03-04
业界
普通人是否需要接触 OpenClaw?我的答案是:值得,但要注意安全风险
1
233
茅香馨
2026-03-08
安全
空论是否有思想史意义?
0
1006
吁寂
2026-03-10
业界
MySQL不推荐使用UUID等字符串做主键
0
614
司寇涵涵
2026-03-15
安全
Fastjson枚举反序列化:当字符串不是枚举常量名时,会发生什么?
0
164
鲫疹
2026-03-19
回复
(30)
鞍汉
2025-10-20 04:46:04
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,试用一下
判涔
2025-10-30 00:46:44
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
这个有用。
凳舒
2025-10-30 22:52:44
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢发布原创作品,程序园因你更精彩
奸轲嫣
2025-11-30 04:51:29
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢分享,学习下。
拼潦
2025-12-14 17:15:18
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
这个有用。
蓝娅萍
2026-1-14 20:16:45
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢,下载保存了
撷监芝
2026-1-17 17:53:25
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢,下载保存了
渭茱瀑
2026-1-18 12:47:35
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
东西不错很实用谢谢分享
虽裘侪
2026-1-22 05:32:40
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
懂技术并乐意极积无私分享的人越来越少。珍惜
碛物
2026-1-22 09:54:05
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,辛苦了
阕阵闲
2026-1-22 22:12:30
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
哈妙思
2026-1-24 08:46:08
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,辛苦了
粉押淫
2026-1-26 12:37:55
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
喜欢鼓捣这些软件,现在用得少,谢谢分享!
兑谓
2026-1-27 02:49:20
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,辛苦了
鞣谘坡
2026-1-30 02:47:50
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
喜欢鼓捣这些软件,现在用得少,谢谢分享!
厥轧匠
2026-2-5 18:00:39
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
不错,里面软件多更新就更好了
梨恐
2026-2-7 15:13:51
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
这个有用。
丧血槌
2026-2-8 04:22:27
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢楼主提供!
闻人莹华
2026-2-8 08:44:11
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢,下载保存了
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
代码
业界
程序
签约作者
程序园优秀签约作者
发帖
辗振
2026-2-8 08:44:11
关注
0
粉丝关注
19
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991125
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
神泱
9522
6
韶又彤
9916
7
宋子
9878
8
荪俗
9018
9
闰咄阅
9995
10
蓬森莉
9870
查看更多
今日好文热榜
195
Electron41+Vite8.0+DeepSeek桌面端AI助手|
674
OPUS编解码器在audio DSP上的移植和应用
469
SpringCloud进阶--Seata与分布式事务
987
大模型私有化部署指南:从“一键安装”到“
624
大模型私有化部署指南:从“一键安装”到“
885
SpringCloud进阶--Seata与分布式事务
171
SpringCloud进阶--Seata与分布式事务
785
Oracle SQL经典练习50题 | 附答案
205
gitru:一个由 Rust 打造的零依赖 Git 提交
929
gitru:一个由 Rust 打造的零依赖 Git 提交
266
gitru:一个由 Rust 打造的零依赖 Git 提交
855
gitru:一个由 Rust 打造的零依赖 Git 提交
426
gitru:一个由 Rust 打造的零依赖 Git 提交
694
ESP32S3 USB MSC 调试全过程记录
639
瑞芯微工业级芯加持,正点原子RK3562J开发
56
gitru:一个由 Rust 打造的零依赖 Git 提交
784
营销自动化数据驱动 - 多源数据 OLAP 架构
534
C# .NET 周刊|2026年3月1期
151
【GUI-Agent】阶跃星辰 GUI-MCP 解读---(5)
869
LangChain教程-3、Langchian进阶