C 练习实例30 - 回文数

该博客介绍了如何判断一个5位数是否为回文数,提供了三种不同的实现方式:逐位分解法、栈以及处理带空格的字符串。通过分解数字并比较各位数字的对应关系,或者利用栈的特性来验证数字的回文性质。这些方法展示了基础的编程思维和数据结构应用。

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

题目:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

程序分析:学会分解出每一位数。

代码1(逐位分解法):

#include <stdio.h>
#include<iostream>
using namespace std;
int main()
{
    long ge, shi, qian, wan, x;
    printf("请输入 5 位数字:");
    cin >> x;
    wan = x / 10000;        /*分解出万位*/
    qian = x % 10000 / 1000;  /*分解出千位*/
    shi = x % 100 / 10;       /*分解出十位*/
    ge = x % 10;            /*分解出个位*/
    if (ge == wan && shi == qian) { /*个位等于万位并且十位等于千位*/
        printf("这是回文数\n");
    }
    else {
        printf("这不是回文数\n");
    }
}

代码2(栈):

#include<iostream>
#include<stack>
using namespace std;
int main()
{
	stack<char>sta;
	string num;
	cin>>num;
	for (int i = 0; i < 5; i++)
		sta.push(num[i]);
	for (int i = 0; i < 5; i++)
	{
		cout << sta.top();
		sta.pop();
	}
	return 0;
}

代码3(带空格的字符串):

#include<iostream>
#include<stack> 
#define MAXSIZE 100
using namespace std;
int main()
{
	stack<char>sta;
	char ch[MAXSIZE];
	cin.get(ch, MAXSIZE);
	int len = 0;
	while (ch[len] != '\0')
	{
		len++;
	}//获取长度
	for (int i = 0; i < len; i++)
		sta.push(ch[i]);
	for (int i = 0; i < len; i++)
	{
		cout << sta.top();
		sta.pop();
	}
	return 0;
} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码骑士

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值