/*========================================================================
排队游戏
总时间限制: 1000ms 内存限制: 65536kB
描述
在幼儿园中,老师安排小朋友做一个排队的游戏。首先老师精心的把数目相同的小男孩和小女孩编排在一个队列中,每个小孩按其在队列中的位置发给一个编号(编 号从0开始)。然后老师告诉小朋友们,站在前边的小男孩可以和他后边相邻的小女孩手拉手离开队列,剩余的小朋友重新站拢,再按前后相邻的小男孩小女孩手拉 手离开队列游戏,如此往复。由于教师精心的安排,恰好可以保证每两个小朋友都能手拉手离开队列,并且最后离开的两个小朋友是编号最小的和最大的两个小朋 友。(注:只有小男孩在前,小女孩在后,且他们两之间没有其他的小朋友,他们才能手拉手离开队列)。请根据老师的排队,按小女孩编号从小到大的顺序,给出 所有手拉手离开队列的小男孩和小女孩的编号对。 输入
用一个字符串代表小朋友队列。字符串中只会出现两个字符,分别代表小男孩和小女孩,首先出现的字符代表小男孩,另一个字符代表小女孩。小孩总数不超过100
输出
按小女孩编号顺序,顺序输出手拉手离开队列的小男孩和小女孩的编号对,每行一对编号,编号之间用一个空格分隔。
样例输入
((()(())())(()))
样例输出
2 3
5 6
4 7
8 9
1 10
12 13
11 14
0 15 解析:这个题要用到栈的思想。但注意,女生和男生在队列里出现的顺序
不合适则可能会使得 部分女生没法往前找到 对应的男生离开队列。
比如下面的输入:
aaabbbbbbbaaaa
前三个男生跟他们后面的三个女生离开,这样一来 ,后面的四个女生没法往前面找到对应
的男生一起离开。 因为还有四个男生在后面还没进栈。
我下面的代码对此的处理就是直接return 结束程序了。这样处理不是很好,但这个情况在
题目里面 没说怎么处理,而且题目本意似乎不该有这样的输入的。再说了,这个处理方法竟然AC了。
==========================================================================*/
#include<stdio.h>
struct stu
{
int number;
char xingBie;
};
int main()
{
char boy,ch;
int end=,num=;
struct stu a[];
freopen("6.in","r",stdin);
scanf("%c",&boy);
a[].xingBie=boy;
a[].number=num;
while(scanf("%c",&ch)!=EOF)
{
if(ch==boy)
{
end++;
num++;
a[end].xingBie=ch;
a[end].number=num; }
else
{
num++;
printf("%d %d\n",a[end].number,num);
end--;
if(end<)
return ;
}
}
return ;
}

递归的代码:

 #include<stdio.h>
#include<string.h> char str[];
int len;
char boy; int fun(int nowIndex);
int main(int argc, char *argv[])
{
freopen("data.in","r",stdin);
scanf("%s",str); boy=str[];
len=strlen(str);
fun();
return ;
}
int fun(int nowIndex)
{
int girlIndex;
if(nowIndex!=len)
{
if(str[nowIndex]==boy)
{
girlIndex=fun(nowIndex+);
if(girlIndex!=-)
{
printf("%d %d\n",nowIndex,girlIndex);
return fun(girlIndex+);//这一行的参数非常重要,一定要从girlIndex下一个位置继续扫描
}
}
else return nowIndex;//遇到的是代表小女孩的字符,返回其下标
}
return -;
}

上述递归代码参考了以下代码:(http://blog.csdn.net/abc8730866/article/details/56901667)

 #include <iostream>
using namespace std;
char man;
//参数;char str[],字符串
//int s,开始位置
//返回值:返回本层的右括号位置
int founction(char str[], int s)
{
int n;
if (str[s] != man)
{
return s;
}
else
{
n = founction(str, s + );
cout << s << ' ' << n << endl;
return founction(str, n + );
}
}
int main()
{
char str[] = { };
cin >> str;
man = str[];
int n = founction(str, );
cout << "0 " << n << endl;
return ;
}

OpenJudge计算概论-排队游戏【这个用到了栈的思想】的更多相关文章

  1. OpenJudge计算概论-取石子游戏

    OpenJudge计算概论-取石子游戏[函数递归练习] /*====================================================================== ...

  2. Openjudge计算概论——数组逆序重放【递归练习】

    /*===================================== 数组逆序重放 总时间限制:1000ms 内存限制:65536kB 描述 将一个数组中的值按逆序重新存放. 例如,原来的顺 ...

  3. OpenJudge计算概论-计算书费

    /*============================================== 计算书费 总时间限制: 1000ms 内存限制: 65536kB 描述 下面是一个图书的单价表: 计算 ...

  4. OpenJudge计算概论-最高的分数

    /*======================================================== 最高的分数 总时间限制: 1000ms 内存限制: 65536kB 描述 孙老师 ...

  5. OpenJudge计算概论-比饭量【枚举法、信息数字化】

    /*====================================================================== 比饭量 总时间限制: 1000ms 内存限制: 655 ...

  6. Openjudge计算概论-角谷猜想

    /*===================================== 角谷猜想 总时间限制: 1000ms 内存限制: 65536kB 描述 所谓角谷猜想,是指对于任意一个正整数,如果是奇数 ...

  7. OpenJudge计算概论-字符串最大跨距

    /*====================================================================== 字符串最大跨距 总时间限制: 1000ms 内存限制: ...

  8. Openjudge计算概论-求序列中的众数

    /*===================================== 求序列中的众数 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一个长度为N的整数序列 (不多于128 ...

  9. OpenJudge计算概论-计算鞍点

    /*======================================================================== 计算鞍点 总时间限制: 1000ms 内存限制: ...

随机推荐

  1. 解决div里插入img下边缝隙问题

    <html>   <head>   <title> new document </title>   <meta name="author ...

  2. 第一个Sprint冲刺第四天

    讨论成员:邵家文.李新.朱浩龙.陈俊金 讨论问题:掌握计时技术的知识 讨论地点:qq网络 进展:即将开始对计时技术代码的编写

  3. Js全选,插入实现

    //全选 function CheckAll() { ids.splice(0, 1000000); var flag = $("#All_Check").attr("c ...

  4. 故事板(Storyboard)

    1 使用Storyboard完成各项常见功能 1.1 问题 故事板Storyboard是IOS5开始引入的一个新的系统,将多个视图文件(类似xib文件)集中到一个单独的可视化工作区间,负责创建和管理所 ...

  5. 解析nginx负载均衡

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://baidutech.blog.51cto.com/4114344/1033718 ...

  6. 基于 OpenSSL 的 CA 建立及证书签发 【转】

    建立 CA 建立 CA 目录结构 按照 OpenSSL 的默认配置建立 CA ,需要在文件系统中建立相应的目录结构.相关的配置内容一般位于 /usr/ssl/openssl.cnf 内,详情可参见 c ...

  7. ubuntu默认root密码

    安装完Kubuntu后一直都是用我的用户名bbking登录, 一直没想到root的问题, 以为每次sudo输入的密码就是我的root密码. 刚才为了修改文件夹的所有者,想使用su root切换到roo ...

  8. Codeforces Round #260 (Div. 2) A B C 水 找规律(大数对小数取模) dp

    A. Laptops time limit per test 1 second memory limit per test 256 megabytes input standard input out ...

  9. spark与storm的对比

    对比点 Storm Spark Streaming 实时计算模型 纯实时,来一条数据,处理一条数据 准实时,对一个时间段内的数据收集起来,作为一个RDD,再处理 实时计算延迟度 毫秒级 秒级 吞吐量 ...

  10. 骑士问题(knight) (BFS)

    题目描述 在一个标准8×8的国际象棋棋盘上,棋盘中有些格子可能是有障碍物的.已知骑士的初始位置和目标位置,你的任务是计算出骑士最少需要多少步可以从初始位置到达目标位置.有障碍物的格子当然不可以到达. ...