题目描述:

给出一个不多于 5 位的整数,要求:

1、求出它是几位数 

2、分别输出每一位数字 

3、按逆序输出各位数字,例如原数为 321,应输出 123

输入:

一个不大于5位的数字

输出

一共三行,第一行:位数 

第二行: 用空格分开的每个数字,注意最后一个数字后没有空格 

第三行: 按逆序输出这个数

样例输入:

12345

样例输出:

5

1 2 3 4 5

54321


解题思路:



先定义一个数组用来存放每一位数字,再定义一个 n 作为输入的数,接着定义一个 number 来记录是几位数。


定义一个 for 循环,n % 10 的值赋给 num[],这样就可以获取得最后一个数;n = n / 10 向前进位,n 是没有小数位的。此时 num[] 这个数组里面的数字和输入的顺序是相反的。


再定义一个 for 循环,倒过来输出 num[],记住用空格分开的每个数字,注意最后一个数字后没有空格。


最后按照 num[]的顺序输出,也就是逆序输出。




参考代码:



#include<iostream>
using namespace std;
int main()
{
	int num[5];  //定义一个有 5 个元素的数组
	int n;
	int number = 0; //记录数位
	cin >> n;  //获取输入的数
	for (int i = 0; i < 5; i++) {  //
		if (n == 0) break;  //如果输入的数为 0 则退出这个循环
		else {
			num[i] = n % 10;  //获取最后一位数,num[0] 为最后一个数,num[1] 是倒数第二个数
			n = n / 10;  //n 向前进 1 位,无小数点
			number++;
		}
	}
	cout << number << endl;  //输出数位
	for (int i = number - 1; i >= 0; i--) {
		if (i != 0) {  //如果 num[i] 不是最后一个数,则加一个空格
			cout << num[i] << " ";
		}
		else cout << num[i];  //输出最后一个数
	}
	cout << endl;  //换行
	for (int i = 0; i < number; i++) {
		cout << num[i];  //按照 num[i] 顺序输出
	}
	return 0;
}

本地运行结果如下图:Project4_2018-08-06_17-37-27.png

点赞(21)
 

0.0分

74 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 57 条评论

余生请多指教 5年前 回复TA
#include<stdio.h>

int main()
{
    int usee,a[5];
    int sum=0;
    scanf("%d",&usee);
    int n=0;
    for(int i=0; i<5; i++) {

        a[i]=usee%10;
        usee=usee/10;
        n++;
        if(usee==0)break;
    }
    printf("%d\n",n);
    for(int j=0; j<n; j++) {

        printf("%d ",a[j]);
        sum=sum+a[j]*pow(10,(n-j-1));
    }
    printf("\n%d",sum);
    return 0;
}
D164805414 5年前 回复TA
你们这也太复杂了吧  看看我的#include<stdio.h>
int main()
{
	int a,i,j,c[5];
	scanf("%d",&a);
	i=0;
	while(a!=0)
	{
		c[i]=a%10;
		a=a/10;
		i++;
	}
	printf("%d\n",i);

		for(j=i-1;j>=0;j--)
	{
		printf("%d",c[j]);
		printf(" ");
	}
		printf("\n");

		for(j=0;j<i;j++)
	{
		printf("%d",c[j]);
	}
		printf("\n");
		return 0;
	

}
进击的毛毛虫 5年前 回复TA
#include<stdio.h>
#include<stdlib.h>
int main()
{
	int str[5] = { 0 };
	int sum, i=0, j=0, n = 1;
	scanf("%d", &sum);
	if (sum > 99999)
		return 0;
	while ((sum / n) > 0)  //确定有几位,通过求摸来实现
	{
		n *= 10;
		j++;
	}
	printf("%d\n", j);
	n = 1;
	for (i = 0; i < j; i++)   //利用得到的位数值将每一位分解并存入数组中。
	{		
		str[i] = sum / n % 10;
		n *= 10;
	}	
	for (i = j-1; i >= 0; i--)//打印每一个数。
	{
		printf("%d ", str[i]);
	}
	printf("\n");
	for (i = 0; i < j; i++)//反向打印每一个数。
	{
		printf("%d", str[i]);
	}
	system("pause");
	return 0;

}
大米哟大米 5年前 回复TA
#include "stdafx.h"
using namespace std;

int digits(int);
void number(int, int);
void backwards(int, int);

int main()
{
	int num;
	cout << "Please input a number:";
	while (cin >> num) {
		cout << "There are " << digits(num) << " numbers." << endl;
		number(num, digits(num));
		backwards(num, digits(num));
		cout << "Please input a number:";
	}
	system("Pause");
    return 0;
}

int digits(int _num) {
	int _digits = 1;
	while (_num / 10 != 0) {
		_digits++;
		_num = _num / 10;
	}
	return _digits;
}

void number(int _num,int _digits) {
	while (_digits != 0) {
		cout << _num / (int)pow(10, _di
云路 5年前 回复TA
#include <stdio.h>

int main(int argc, char** argv) 
{
	int x,a,b,c,d,e;
	
	scanf("%d",&x);
	a=x/10000;
	b=x%10000/1000;
	c=x%1000/100;
	d=x%100/10;
	e=x%10;
	if(a!=0){
	
	printf("5\n%d %d %d %d %d\n%d%d%d%d%d\n",e,d,c,b,a,e,d,c,b,a);
}
else if(b!=0){
	
   printf("4\n%d %d %d %d\n%d%d%d%d\n",e,d,c,b,e,d,c,b);
}
else if(c!=0){
	
 printf("3\n%d %d %d\n%d%d%d\n",e,d,c,e,d,c);
}
else if(d!=0){
	
	printf("2\n%d %d\n%d%d\n",e,d,e,d);
}
	else
	printf("1\n%d\n%d\n",e,e); 
	
	return 0;
}
不明所以 5年前 回复TA
#include <stdio.h>
#include <math.h>
int main()
{
    int i,j,m=0,n=0;
    scanf("%d",&i);
    j=i;
    while(i)//位数
    {
        i /=10;
        n++;
    }
    printf("%d\n",n);
    i=j;
    while(i)//空格输出
    {
        m =i / pow(10,n - 1);
        i -= m * pow(10,n-1);
        n--;
        if(i<0)
            break;
        printf("%d ",m);
    }
    printf("\n");
    n=0;//逆输出
    while(j)
    {
        n =j % 10;
        printf("%d",n);
        j /= 10;
    }
    return 0;
}
小白的我写出来的,纯数学方法……
修仙ing 5年前 回复TA
@兔子叔叔 你不会是个憨憨吧,有限制条件没看到吗?n==0就终止,不会往下去执行了。
兔子叔叔 5年前 回复TA
要是输入的数字中间有零,那岂不是玩完了。。。。
majiko 5年前 回复TA
@YAO i=len-1;
洛洛桑 5年前 回复TA
@YAO 不要加汉字,而且最后一行输出也没有