while(!Q.empty()) //队列不空,执行循环做取出队头的值操作的时候,并不弹出当前队头。
{
int x=Q.front(); //取出当前队头的值x
Q.pop(); //弹出当前队头
Q.push(x); //把x放入队尾
x = Q.front(); //取出这时候队头的值
printf("%d\n",x); //输出x
Q.pop(); //弹出这时候的队头
}
第一行一个整数T(T ≤ 100)表示数据组数,每组数据输入一个数n(1 ≤ n ≤ 100000),输入的所有n之和不超过200000。
对于每组数据,输出一行,表示原始的队列。数字之间用一个空格隔开,不要在行末输出多余的空格.
4
1
2
3
10
1
2 1
2 1 38 1 6 2 10 3 7 4 9 5
方法还是暴力法,直接生成顺序 然后逆推找回对应的数字。
然后这道题发现了,C++里直接就有队列可以用
<span style="color:#ff0000;">#include<queue></span><span style="color:#ff0000;">queue<int> Q;</span>#include<stdio.h>#include<iostream>#include<queue>using namespace std;queue<int> Q;int sequence[100001];void makeQuene(int num);void makeQuene(int num){for (int i = 1; i <= num; i++){Q.push(i);}int k = 1;while (!Q.empty()) //队列不空,执行循环{int x = Q.front(); //取出当前队头的值xQ.pop(); //弹出当前队头Q.push(x); //把x放入队尾x = Q.front(); //取出这时候队头的值//printf("%d\n", x); //输出xsequence[x] = k;k++;Q.pop(); //弹出这时候的队头}//输出队列for (int i = 1; i < num; i++){printf("%d ", sequence[i]);}printf("%d\n", sequence[num]);}int main(){int n;int num;cin >> n;for (int i = 0; i < n; i++){cin >> num;makeQuene(num);}return 0;}
本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。