读取123.txt,里面含有以下几种指令:
ADD_F ADD_B REMOVE_F REMOVE_B RESULT
开始要求创建一个空数组
例如
ADD_F 2 3 5:在数组开头增加2 3 5
ADD_B 3 5 6:在数组结尾增加3 5 6
REMOVE_F 3:删掉数组头3个数字
REMOVE_B 2:删掉数组后2个数字
RESULT:输出当前数组
例子
ADD_F 1 2 3
ADD_B 5 6 7
RESULT
1 2 3 5 6 7
REMOVE_F 2
REMOVE_B 2
RESULT
3 5
就你的问题来说,最好的做法是双向循环链表。
http://www.tuicool.com/articles/zEVnUvQ
这个题有趣,相当于在做汇编程序,基本思想是这样的。
std::list
其實這没什么什么很深的算法学问啊,基本的解题思路如下:
如果伪指令还需要中间指定位位置插入,那在数据量不多的前提下用一般的数组结结构加一点数组分割重组的代码就可以了。
但是大量数据的情况下就不能这样做了,十分高耗,按caozhy提议用链表更佳。
flex和bison能够很好地处理这个问题。