OpenJudge计算概论-扩号匹配问题【这个用到了栈的思想】
/*======================================================================
扩号匹配问题
总时间限制: 1000ms 内存限制: 65536kB
描述
在某个字符串(长度不超过100)中有左括号、右括号和大小写字母;规定(与常见的算数式子一样)任何一个左括号都从内到外与在它右边且距离最近的右括号匹配。写一个程序,找到无法匹配的左括号和右括号,输出原来字符串,并在下一行标出不能匹配的括号。不能匹配的左括号用"$"标注,不能匹配的右括号用"?"标注.
输入
输入包括多组数据,每组数据一行,包含一个字符串,只包含左右括号和大小写字母,字符串长度不超过100
注意:cin.getline(str,100)最多只能输入99个字符!
输出
对每组输出数据,输出两行,第一行包含原始输入字符,第二行由"$","?"和空格组成,"$"和"?"表示与之对应的左括号和右括号不能匹配。
样例输入
((ABCD(x)
)(rttyy())sss)(
样例输出
((ABCD(x)
$$
)(rttyy())sss)(
? ?$ 思路:
输入一组数据后(一个字符串,这里输入到数组a),先输出数组a
统计数组a的长度len,设置数组b代表的栈的栈顶end指向0. (注意把end清零)
然后扫描检测数组a,遇到左括号之间进栈(数组b代表的栈的元素存储进栈的
那个字符以及该字符在字符串a中的下标。)遇到右括号则按下面法则处理:
假如数组b代表的栈是空的(即end为0),则右括号进栈。
假如b不是空的(end大于0),则检测栈顶元素(下标是end-1)
是否是左括号,如果刚好是左括号则该栈顶元素出栈(end自己减1),
假如栈顶元素(下标是end-1)不是左括号,则该右括号进栈。 注意:这里end是指向栈顶元素的下一个位置。也就是说某一次进栈后end自己加1,
而栈顶元素下标是end-1。 另外:扫描完后,b数组的下标应该是0到end-1.扫描该数组,
按b的每一个元素的num值所指向的a数组的下标对应的元素设置为$或?
然后扫描a数组,假如不是$或?则输出空格,否则输出对应元素的值 然后处理下一组数据(但是要注意处理下一组数据前要把end清零。)
========================================================================*/
#include<stdio.h>
#include<string.h>
struct s
{
char ch;
int num;
};
int main()
{
char a[];
struct s b[];
int i,len;
int end=;//指向b数组代表的栈的栈顶
freopen("5.in","r",stdin);
while(scanf("%s",a)!=EOF)
{
printf("%s\n",a);
len=strlen(a);
end=;
for(i=;i<len;i++)
{
if(a[i]=='(')//左括号直接进栈(因为它不可能使栈顶元素出栈的。)
{
b[end].ch=a[i];
b[end].num=i;
end++;
}
else if(a[i]==')')
{
if(end==)//b数组代表的栈是空的
{
b[end].ch=a[i];
b[end].num=i;
end++;
}
else
{
if(b[end-].ch=='(')
{
end--;
}
else
{
b[end].ch=a[i];
b[end].num=i;
end++;
}
}
}
}
for(i=;i<end;i++)
{
if(b[i].ch=='(')
{
a[b[i].num]='$';
}
else
{
a[b[i].num]='?';
}
}
for(i=;i<len;i++)
{
if(a[i]!='$'&&a[i]!='?')
{
printf(" ");
}
else printf("%c",a[i]);
}
printf("\n");
/*for(i=0;i<end;i++)
{
printf("%c ",b[i].ch);
}
printf("\n");
for(i=0;i<end;i++)
{
printf("%d ",b[i].num);
}
printf("\n");*/
}
return ;
}
OpenJudge计算概论-扩号匹配问题【这个用到了栈的思想】的更多相关文章
- OpenJudge计算概论-取石子游戏
OpenJudge计算概论-取石子游戏[函数递归练习] /*====================================================================== ...
- Openjudge计算概论——数组逆序重放【递归练习】
/*===================================== 数组逆序重放 总时间限制:1000ms 内存限制:65536kB 描述 将一个数组中的值按逆序重新存放. 例如,原来的顺 ...
- OpenJudge计算概论-计算书费
/*============================================== 计算书费 总时间限制: 1000ms 内存限制: 65536kB 描述 下面是一个图书的单价表: 计算 ...
- OpenJudge计算概论-最高的分数
/*======================================================== 最高的分数 总时间限制: 1000ms 内存限制: 65536kB 描述 孙老师 ...
- OpenJudge计算概论-排队游戏【这个用到了栈的思想】
/*======================================================================== 排队游戏 总时间限制: 1000ms 内存限制: ...
- Openjudge计算概论-求序列中的众数
/*===================================== 求序列中的众数 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一个长度为N的整数序列 (不多于128 ...
- OpenJudge计算概论-找最大数序列
/*===================================== 找最大数序列 总时间限制: 1000ms 内存限制: 65536kB 描述 输入n行(n 不大于 30),每行不超过10 ...
- OpenJudge计算概论-比饭量【枚举法、信息数字化】
/*====================================================================== 比饭量 总时间限制: 1000ms 内存限制: 655 ...
- Openjudge计算概论-角谷猜想
/*===================================== 角谷猜想 总时间限制: 1000ms 内存限制: 65536kB 描述 所谓角谷猜想,是指对于任意一个正整数,如果是奇数 ...
随机推荐
- 三色二叉树_树形DP
Time Limit: 1000 mSec Memory Limit : 32768 KB Problem Description 一棵二叉树可以按照如下规则表示成一个由0.1.2组成的字符序 ...
- nginx+fast-cgi+c
1. 下载fastcgi开发包,编译安装 http://www.fastcgi.com/dist/fcgi-current.tar.gz #wget http://www.fastcgi.com/di ...
- 贝努利概率 matlab
参考:http://zhidao.baidu.com/link?url=3XZm35XpFf_kbADwDHEERtgFMKqHftiS5SyTCWcBtlF7B7zeNgoNqIzXxpJsHtBI ...
- 深入理解JavaScript闭包
Closure 闭包的定义1: <JavaScript高级程序设计>定义闭包:闭包是指有权访问另一个函数作用域中的变量的函数. 创建闭包的常见方式,就是在一个函数内部创建另一个函数. 然而 ...
- VMware虚拟机固定IP后克隆出现无法访问网卡问题
通常我们现在都喜欢使用虚拟机进行实验,进行集群搭建等,在这个过程中,会遇到克隆虚拟机问题,当没有修改任何IP的情况下,克隆后,在逐台修改IP地址是没有问题的,但是,如果我们先设置了固定IP地址后,克隆 ...
- PAT (Basic Level) Practise:1027. 打印沙漏
[题目链接] 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打印 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输出奇数个符号:各行符号中 ...
- The Hidden Pitfalls of AsyncTask
http://logc.at/2011/11/08/the-hidden-pitfalls-of-asynctask/
- 递归神经网络(RNN,Recurrent Neural Networks)和反向传播的指南 A guide to recurrent neural networks and backpropagation(转载)
摘要 这篇文章提供了一个关于递归神经网络中某些概念的指南.与前馈网络不同,RNN可能非常敏感,并且适合于过去的输入(be adapted to past inputs).反向传播学习(backprop ...
- js部分---表单验证;(含正则表达式)
1.非空验证 <div>用户名:<input id="yhm" type="text" name="yhm" />& ...
- Codeforces Round #130 (Div. 2)
A. Dubstep 字符串模拟. string.find()用法 string str; size_t pos = str.find("WUB"); // 返回匹配的第一个位置 ...