01
在编程开发中,有时候可能需要项目需求需要,对字符串中的括号符比如说(){}[]进行匹配判断,但是C语言不像其他高级语言语言拥有那么多方便的库函数,这个需要自己去实现,那么看到这里,如果你采用C语言去实现这一过程,你能想到几种实现方法呢?图控大叔在这里使用二维数组去实现了这一过程,具体代码如下:
#include #include void string_matching(){char get_str[1024][1024]={{0}};strcpy(get_str[2], (char *)"({["); //自定义需要匹配的字符串strcpy(get_str[3], (char *)")}]"); //自定义需要匹配的字符串int str_num=0, i=0, j=0, k=0;scanf("%[^\n]",get_str[0]);//输入带空格的字符串strcpy(get_str[1], get_str[0]); //备份字符串for(str_num=0; str_num<1024; str_num++) //先获取字符个数
{if(get_str[1][str_num] == '\0')break;
}printf("get_str[0]%s %d\n", get_str[1], str_num);printf("get_str[1]%s\n", get_str[2]);printf("get_str[2]%s\n", get_str[3]);for(i=0; i {if(get_str[1][i] == '\0')break;for(j=0; j<3; j++)
{if(get_str[1][i] == get_str[2][j]) //先匹配左符
{for(k=i; k {if(get_str[1][k] == get_str[3][j]) //左符匹配则继续匹配右符
{printf("%c%c\n", get_str[2][j], get_str[3][j]);
get_str[1][k] = ' '; //将匹配成功的位置置空格符
get_str[1][i] = ' '; //将匹配成功的位置置空格符break;
}
}
}
}
}
}int main(){
string_matching();return 0;
}
02
代码中对于原字符串进行了备份,并且加入了细节使括号符匹配过程中避免重复判断。今天的分享就先到这里,赶紧去试试,让代码跑起来吧!