判断位数、按位输出、倒序输出(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流程图;

相关推荐
sali-tec几秒前
C# 基于OpenCv的视觉工作流-章80-长短脚
图像处理·人工智能·opencv·算法·计算机视觉
Xin_ye100867 分钟前
C# 零基础到精通教程 - WPF 专题二:数据绑定与 MVVM
开发语言·c#·wpf
sul.i11 分钟前
浅析·指针
算法
我是一颗柠檬12 分钟前
【Java后端技术亮点】Feed流三级缓存设计,从10秒到100毫秒的优化实战
java·开发语言·后端·缓存
春日见13 分钟前
策略梯度算法
算法
兆。13 分钟前
LangChain文档处理集成指南:面向知识管理开发者
开发语言·langchain·c#
Brilliantwxx14 分钟前
【算法从零到千】【1-7】 双指针算法
开发语言·c++·笔记·算法·leetcode·推荐算法
社交怪人14 分钟前
【三个数】信息学奥赛一本通C语言解法(题号2053)
c语言
小许同学记录成长16 分钟前
孔洞修补算法
算法
随意起个昵称17 分钟前
线性dp-计数类题目9(斐波那契字符串)
算法·动态规划