?? 浙大1016(ac).cpp
字號:
#include<stdio.h>
int main()
{
int p[20],w[20],i,sign,a,b;
scanf("%d",&a);
for(;a>0;a--)
{
scanf("%d",&b);
for(i=0;i<b;i++)
{
scanf("%d",&p[i]);
}
for(i=b-1;i>0;i--)
{
p[i]-=p[i-1];//先做差存入p隊列
}
for(i=0;i<b;i++)
{
if(p[i]!=0)
{
w[i]=1;//如果差不為0,說明此)與前一個)之間有至少一個(,所以只含一對
p[i]-=1;
}
else
{
sign=i;
while(p[sign]==0)//直到前一個不為0的差
sign--;
w[i]=i-sign+1;
p[sign]-=1;
}
}
for(i=0;i<b-1;i++)
{
printf("%d ",w[i]);
}
printf("%d\n",w[b-1]);
}
return 0;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -