数据结构实验之栈六:下一较大值(二)
2017-06-03 19:45
183 查看
# include <bits/stdc++.h>
# include <algorithm>
# include <stack>
using namespace std;
struct node
{
int data, place, next;
} z[100010];
int main()
{
int T;
while(~scanf("%d",&T))
{
while(T--)
{
int n;
scanf("%d",&n);
stack<struct node>Q;
int i;
for(i=0; i<n; i++)
{
scanf("%d",&z[i].data);
z[i].place=i;
z[i].next=-1;
if(Q.empty())
{
Q.push(z[i]);
}
else
{
while(!Q.empty())
{
struct node t=Q.top();
if(z[i].data>t.data)
{
z[t.place].next=z[i].data;
Q.pop();
}
else
break;
}
Q.push(z[i]);
}
}
for(i=0; i<n; i++)
printf("%d-->%d\n",z[i].data,z[i].next);
if(T!=0)
printf("\n");
}
}
return 0;
}
# include <algorithm>
# include <stack>
using namespace std;
struct node
{
int data, place, next;
} z[100010];
int main()
{
int T;
while(~scanf("%d",&T))
{
while(T--)
{
int n;
scanf("%d",&n);
stack<struct node>Q;
int i;
for(i=0; i<n; i++)
{
scanf("%d",&z[i].data);
z[i].place=i;
z[i].next=-1;
if(Q.empty())
{
Q.push(z[i]);
}
else
{
while(!Q.empty())
{
struct node t=Q.top();
if(z[i].data>t.data)
{
z[t.place].next=z[i].data;
Q.pop();
}
else
break;
}
Q.push(z[i]);
}
}
for(i=0; i<n; i++)
printf("%d-->%d\n",z[i].data,z[i].next);
if(T!=0)
printf("\n");
}
}
return 0;
}
相关文章推荐
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 3333 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 暑假集训 7.30 数据结构实验之栈六:下一较大值(二)sdut oj3333(手写栈)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- SDUTACM 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)
- 数据结构实验之栈六:下一较大值(二)