//C v0.01 不知题意,正在理解,正在(一)上修改。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define STACK_SIZE 10000
typedef struct STACK{
char stack[STACK_SIZE];
int pointer;
}STSTACK;
STSTACK stack;
void push(char ch);
char pop();
int main(int argc, char *argv[])
{
int num;
int i;
char buf[STACK_SIZE]={0};
int sum = 0;
scanf("%d",&num);
getchar();
for(i = 0;i < num;i++){
memset(stack.stack, 0x00, STACK_SIZE);
stack.pointer = -1;
scanf("%s", buf);
getchar();
int len = strlen(buf);
//printf("%d\n",len);
int j;
int flag=1;
for(j = 0;j < len;j++){
char tmp;
if(buf[j] == '[' || buf[j] == '('){
push(buf[j]);
}else if (buf[j] == ']') {
if(stack.pointer == -1){
//--stack.pointer;
flag = 0;
push(buf[j]);
//++sum;
//printf("No\n");
//break;
continue;
}
tmp = pop();
if(tmp != '['){
//push(tmp);
//printf("No\n");
flag = 0;
push(tmp);
push(buf[j]);
//break;
continue;
}/*else if(tmp == '['){
continue;
}*/
}else if (buf[j] == ')') {
if(stack.pointer == -1){
// --stack.pointer;
flag = 0;
push(buf[j]);
//++sum;
//printf("No\n");
//break;
continue;
}
tmp = pop();
if(tmp != '('){
//push(tmp);
//printf("No\n");
flag = 0;
push(tmp);
push(buf[j]);
//break;
continue;
}/*else if(tmp == '('){
continue;
}*/
}
}
if(stack.pointer == -1 && flag){
//printf("Yes\n");
printf("0\n");
}else{
//printf("No\n");
printf("%d\n",stack.pointer+1);
}
}
return 0;
}
void push(char ch){
stack.stack[++stack.pointer] = ch;
}
char pop(){
return stack.stack[stack.pointer--];
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!