OpenJudge上的一道题,
遇到的问题是Wrong Answer,不知道是哪个地方考虑不周没想到。
具体题目:
在幼儿园中,老师安排小朋友做一个排队的游戏。首先老师精心的把数目相同的小男孩和小女孩编排在一个队列中,每个小孩按其在队列中的位置发给一个编号(编 号从0开始)。然后老师告诉小朋友们,站在前边的小男孩可以和他后边相邻的小女孩手拉手离开队列,剩余的小朋友重新站拢,再按前后相邻的小男孩小女孩手拉 手离开队列游戏,如此往复。由于教师精心的安排,恰好可以保证每两个小朋友都能手拉手离开队列,并且最后离开的两个小朋友是编号最小的和最大的两个小朋 友。(注:只有小男孩在前,小女孩在后,且他们两之间没有其他的小朋友,他们才能手拉手离开队列)。请根据老师的排队,按小女孩编号从小到大的顺序,给出 所有手拉手离开队列的小男孩和小女孩的编号对。
样例输入
((()(())())(()))
样例输出
2 3
5 6
4 7
8 9
1 10
12 13
11 14
0 15
我的代码:
#include<iostream>
using namespace std;
char judge(char c[]) {
int i = 0 ;
int j=0, k=0;
char *sptr;
sptr = c;
while (sptr[i] != ')'&&i<101) {
i++;
}
c[i] = ' ';//此时输出的是遍历过来的第一个右括号,改为空格
k = i;//存放该右括号位置
while (sptr[i] != '(') {
i--;
}
c[i] = ' ';//此时输出的是从获取的右括号起倒数过来的第一个左括号,改为空格
j = i;//存放该左括号位置
cout << j << ' ' << k << endl;
for (int y = 0; y <= k; y++) {//判断是否还有剩余
if (c[y] != ' ') {
break;
}
else {
return 0;
}
}
return judge(c);
}
int main() {
char c[101];
cin.getline(c, 101,'\n');
judge(c);
return 0;
}
這個問題用一個stack就好了:
遞歸代碼, 見 @邊城狂人 的解釋:
如果用遞歸的思想來解決,應該是這樣
定義一個過程,叫配對,其步驟
用演算法表示
初始呼叫(假設 list 一定不空)
遞歸的呼叫方法不會用到很多循環,如果你喜歡用循環,可以採用棧的方式而不是用遞歸(即解遞歸,或者叫展開遞歸)
演算法希望你能看懂,然後自己寫程式碼試驗。如果試驗代碼有問題再拿出來,繼續幫你分析。
js6 程式碼
如果你有iojs 的最新版本,直接儲存成檔案可以運行;如果是nodejs,可能在運行時候需要加一些參數…不過如果你有比較新的瀏覽器(Chrome,或IE11 之類),直接在瀏覽器的開發者視窗可以直接貼上運行。
結果