北大1068题

题目连接:http://acm.pku.edu.cn/JudgeOnline/problem?id=1068

之所以写上来主要是因为自己太贪图技巧了,开始的时候一直去想数字之间的对应关系,没有想到直接模拟。浪费了不少时间。再有字符串的查找函数的第一个参数是要查找的字符,第二个参数是查找的起始下标,str.find(tar,index);

#include <iostream>
#include <string>
using namespace std;

int main()
{
 freopen("in.txt","r",stdin);
 int cases;
 cin >> cases;
 
 int pcode[20],wcode[20],i,j,k,l,n,t;
 string str;
 while(cases > 0)
 {
  cin >> n;
  for(i = 0;i < n;++i)
   cin >> pcode[i];

  for(i = 0;i < pcode[0];++i)
   str += "(";
  str += ")";
  for(i = 1;i < n;++i)
  {
   for(j = 0;j < pcode[i] - pcode[i - 1];++j)
    str += "(";
   str += ")";
  }

  i = l = 0;
  while(true)
  {
   j = str.find(')',i);
   i = j + 1;
   if(j == -1)
    break;

   t = 1;
   for(k = j - 1;k >= 0;--k)
   {
    if(str[k] == '(')
    {
     str[k] = ' ';
     break;
    }
    else if(str[k] == ')')
     ++t;
   }

   wcode[l] = t;
   ++l;
  }

  for(i = 0;i < l;++i)
   cout << wcode[i] << ' ';
  cout << '/n';
  
  str = "";
  --cases;
 }
 return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值