网易有道2017内推编程题2


小明同学把1到n这n个数字按照一定的顺序放入了一个队列Q中。现在他对队列Q执行了如下程序:
while(!Q.empty())              //队列不空,执行循环

{

int x=Q.front(); //取出当前队头的值x

Q.pop(); //弹出当前队头

Q.push(x); //把x放入队尾

x = Q.front(); //取出这时候队头的值

printf("%d\n",x); //输出x

Q.pop(); //弹出这时候的队头

}

做取出队头的值操作的时候,并不弹出当前队头。
小明同学发现,这段程序恰好按顺序输出了1,2,3,...,n。现在小明想让你构造出原始的队列,你能做到吗?[注:原题样例第三行5有错,应该为3,以下已修正] 
输入描述:
第一行一个整数T(T ≤ 100)表示数据组数,每组数据输入一个数n(1 ≤ n ≤ 100000),输入的所有n之和不超过200000。


输出描述:
对于每组数据,输出一行,表示原始的队列。数字之间用一个空格隔开,不要在行末输出多余的空格.

输入例子:
4
1
2
3
10

输出例子:
1
2 1
2 1 3

8 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;}


智能推荐

注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
© 2014-2019 ITdaan.com 粤ICP备14056181号  

赞助商广告