小发现,如何高级的顺序输出,逆序输出整数的每一位(栈,队列)

当我还是初学者的时候,我经常思考有没有比慢慢求每一位数字然后考虑正序,逆序输出要快的办法...长期琢磨,必有所获!

我刚学数据结构的时候还没意识到栈,队列还能这样用,虽然说有点杀鸡用牛刀的感觉,但是这样确实可以加深对栈和队列理解与运用。

开始:

比如输入1234000,顺序输出为1 2 3 4 0 0 0,逆序输出为0 0 0 4 3 2 1

我们知道每次获取最后一位数字的难度是最低的,所以我们就每次将最末尾的数字存放到栈或者队列里就行了。

对于栈,如果按照上面的方式存储就是顺序输出,栈是先进后出,进入就是0 0 0 4 3 2 1 ,而每次弹栈就是输出最上面的那个,就是1 2 3 4 0 0 0,每次弹栈之后删除栈顶元素就行了

对于队列,如果按照上面的方式存储就是逆序输出,队列是先进先出,进入就是0 0 0 4 3 2 1,而每次队头先出来,就是0 0 0 4 3 2 1,每次出队之后删除队首元素就行了

代码实现:

cpp 复制代码
#include<iostream>
#include<stack>//调用栈的头文件
#include<queue>//调用队列的头文件
using namespace std;
int main(){
	stack<int> s;//创建一个栈
	cout << "栈" << endl; 
	int n;
	cin >> n;//输入数字
	while(n>0){
		s.push(n%10);//压栈(存放元素)push()
		n /= 10;
	}
	while(!s.empty()){//判空,如果不是空的就继续输出
		cout << s.top() << " ";//输出栈顶元素,top()
		s.pop();//删除栈顶元素,pop()
	}
	cout << endl << "队列" << endl;
	queue<int> q;//创建一个队列
	cin >> n;
	while(n>0){
		q.push(n%10);//进队
		n/=10;
	}
	while(!q.empty()){//判空,如果不是空的就继续输出
		cout << q.front() << " ";//输出队首元素
		q.pop();//删除队首元素
	}
	return 0;
} 

以上就是我对灵光乍现的代码实现 ,芜湖芜湖~~~

到这里就结束啦!!!

欢迎小伙伴们评论区讨论,提问。

我是荒古前,期待你的关注~~~

~~~完结撒花✌y( •̀ ω •́ )y✌~~~

相关推荐
知识浅谈2 小时前
DeepSeek V4 和 GPT-5.5 在同一天发布了??我也很懵,但对比完我悟了
算法
DeepModel3 小时前
通俗易懂讲透 Q-Learning:从零学会强化学习核心算法
人工智能·学习·算法·机器学习
田梓燊3 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
handler014 小时前
从零实现自动化构建:Linux Makefile 完全指南
linux·c++·笔记·学习·自动化
简简单单做算法4 小时前
基于GA遗传优化双BP神经网络的时间序列预测算法matlab仿真
神经网络·算法·matlab·时间序列预测·双bp神经网络
阿豪学编程5 小时前
面试题map/unordered相关
数据结构
guygg885 小时前
利用遗传算法解决列车优化运行问题的MATLAB实现
开发语言·算法·matlab
武藤一雄5 小时前
19个核心算法(C#版)
数据结构·windows·算法·c#·排序算法·.net·.netcore
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章52-交点查找
图像处理·人工智能·opencv·算法·计算机视觉
梦想的颜色5 小时前
mongoTemplate + Java 增删改查基础介绍
数据结构·数据库·mysql