Problem Description
对于包含n(1<=n<=100000)个整数的序列,对于序列中的每一元素,在序列中查找其位置之后第一个大于它的值,如果找到,输出所找到的值,否则,输出-1。
Input
输入有多组,第一行输入t(1<=t<=10),表示输入的组数;
以后是 t 组输入:每组先输入n,表示本组序列的元素个数,之后依次输入本组的n个元素。
Output
输出有多组,每组之间输出一个空行(最后一组之后没有);
每组输出按照本序列元素的顺序,依次逐行输出当前元素及其查找结果,两者之间以-->间隔。
Example Input
24 12 20 15 185 20 15 25 30 6
Example Output
12-->20
20-->-1
15-->18
18-->-1
20-->25
15-->25
25-->30
30-->-1
6-->-1
Hint
本题数据量大、限时要求高,须借助栈来完成。
#include <bits/stdc++.h>
using namespace std;
struct node
{
int next;//存他所连接的的一个大值
int id;//下标
int num;//数组元素
}a[100005]; //结构体来存数组
int main()
{
stack<struct node>p;//建一个结构体的栈
int t;
scanf("%d",&t);
while(t--)
{
while(!p.empty())//清空栈的操作
{
p.pop();
}
int i,n;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i].num);
a[i].id=i;
a[i].next=-1;//每次都将他所连接的值先赋值成-1(看题目);
if(p.empty())//将第一个值先赋值进数组
p.push(a[i]);
else
{
while(!p.empty())
{
struct node b;
b=p.top();
if(b.num<a[i].num)//当前元素比栈顶元素大,移除栈顶元素,并将其next赋值;
{
a[b.id].next=a[i].num;
p.pop();
}
else break;//否则 直接退出;
}
p.push(a[i]);//每次的值一定会入栈;
}
}
for(i=0;i<n;i++)
printf("%d-->%d\n",a[i].num,a[i].next);
if(t!=0)//格式要求
printf("\n");
}
}