c 语言123变成321编程,实现一个数的反转,即“123”,输出时变为“321”

本文介绍了使用C语言将整数反转的多种方法,包括取余整除、递归函数、队列、字符串遍历以及栈操作。通过实例代码详细讲解了每种方法的实现过程,适合初学者学习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果是明确的三位数,那么很容易实现,使用取余数和整除即可分离出每一位,代码如下:

#includeusing namespace std;

int main()

{

int a;

cin>>a;

cout<

return 0;

}

但是如果不知道是多少位,只知道是整数的话,那么我们可以定义一个递归函数来实现,只是输出的话,代码如下:

#includeusing namespace std;

void out(int a)

{

if(a<10)

cout<

else

{

cout<>a;

out(a);

return 0;

}

还有一种方法就是使用队列,它的特性是先入队的先出队,头文件为#include

#include#includeusing namespace std;

int main()

{

queuenumber;

int a;

int sum=0;

cin>>a;

while(a>0)

{

number.push(a%10);

a=a/10;

}

while(!number.empty())

{

sum=sum*10+number.front();

number.pop();

}

cout<

return 0;

}

如果是字符串,直接把它从后面遍历如下:

#include#include#includeusing namespace std;

int main()

{

stackch;

string s;

cin>>s;

for(int i=s.length()-1;i>=0;i--)

cout<

cout<

return 0;

}

或者改变字符串的值,对称式的一一交换,代码如下:

#include#includeusing namespace std;

int main()

{

string s;

char c;

cin>>s;

for(int j=0;j<=s.length()/2-1;j++)

{

c=s[j];

s[j]=s[s.length()-1-j];

s[s.length()-1-j]=c;

}

cout<

return 0;

}

如果使用栈来处理,代码如下:

#include#include#includeusing namespace std;

int main()

{

string s;

stackch;

cin>>s;

for(int j=0;j<=s.length()-1;j++)

{

ch.push(s[j]);

}

for( j=0;j<=s.length()-1;j++)

{

cout<

ch.pop();

}

cout<

return 0;

}

此文章仅代表自己(本菜鸟)学习积累记录,或者学习笔记,如有侵权,请联系作者删除。人无完人,文章也一样,文笔稚嫩,在下不才,勿喷,如果有错误之处,还望指出,感激不尽~

技术之路不在一时,山高水长,纵使缓慢,驰而不息。

公众号:秦怀杂货店

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值