判断位数、按位输出、倒序输出(C语言)

一、运行结果;

二、源代码;

cs 复制代码
# define _CRT_SECURE_NO_WARNINGS
# include <stdio.h>

int main()
{
	//初始化变量值;
	int number = 0;
	int i = 1;
	int m = 0;
	int z = 0;
	int z1 = 0, z2 = 0, z3 = 0, z4 = 0;

	//提示用户;
	printf("请输入一个不多于5位的正整数:");
	//获取用户输入的数据;
	scanf("%d", &number);

	//循环获取数据
	while (number > 99999 || number < 0)
	{
		//提示用户
		printf("您输入的数据不满足条件!!!!\n");
		printf("请输入一个不多于5位的正整数:");
		//获取用户输入的数据;
		scanf("%d", &number);
	}

	//赋值;
	m = number;

	//循环判断number的位数;
	while (m > 9)
	{
		//运算;
		m = m / 10;

		//更改变量的值;
		i++;
	}

	//输出结果;
	printf("%d是%d位数!!!!\n", number, i);

	//判断每位的数据值,并分别输出每一位数值;
	switch (i)
	{
	case 5:
		//运算;
		z1 = number / 10000;
		number = number % 10000;

		//输出数值;
		printf("万位为%d\n", z1);
	case 4:
		//运算;
		z2 = number / 1000;
		number = number % 1000;

		//输出数值;
		printf("千位为%d\n", z2);
	case 3:
		//运算;
		z3 = number / 100;
		number = number % 100;

		//输出数值;
		printf("百位为%d\n", z3);
	case 2:
		//运算;
		z4 = number / 10;
		number = number % 10;

		//输出数值;
		printf("十位为%d\n", z4);
	case 1:
		//输出数值;
		printf("个位为%d\n", number);
	}

	//倒序输出每位的数据值;
	switch (i)
	{
	case 1:
		//输出;
		printf("倒序为:%d", number);
		break;
	case 2:
		//输出;
		printf("倒序为:%d%d", number, z4);
		break;
	case 3:
		//输出;
		printf("倒序为:%d%d%d", number, z4, z3);
		break;
	case 4:
		//输出;
		printf("倒序为:%d%d%d%d", number, z4, z3, z2);
		break;
	case 5:
		//输出;
		printf("倒序为:%d%d%d%d%d", number, z4, z3, z2, z1);
		break;
	}

	return 0;
}

三、N-S流程图;

相关推荐
会员源码网12 小时前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing13 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader14 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱17 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng89718 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮1 天前
AI视觉连载8:传统 CV 之边缘检测
算法
RuoZoe1 天前
重塑WPF辉煌?基于DirectX 12的现代.NET UI框架Jalium
c语言
AI软著研究员2 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish2 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱2 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法