伪君子


私信TA

用户名:lbj

访问量:92952

签 名:

我觉得吧,能实现就好^_^

等  级
排  名 46
经  验 12169
参赛次数 0
文章发表 23
年  龄 20
在职情况 学生
学  校 山西工程技术学院
专  业

  自我简介:

个人博客:https://lbjheiheihei.xyz 微信公众号:伪君子的梦呓

题目描述:

给出一个不多于 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

 

0.0分

114 人评分

  评论区

if(x<=9){
		printf("1\n");
	    printf("%d\n",x);
		printf("%d\n",x);}
	else if(x>9&&x<100){
		printf("2\n");
		printf("%d %d\n",x/10,x%10);
		printf("%d%d\n",x%10,x/10);}
	else if(x>=100&&x<=999){
		printf("3\n");
		printf("%d %d %d\n",x/100,x/10%10,x%10);
		printf("%d%d%d\n",x%10,x/10%10,x/100);}
	else if(x>=1000&&x<=9999){
		printf("4\n");
		printf("%d %d %d %d \n",x/1000,x/100%10,x%100/10,x%10);
		printf("%d%d%d%d \n",x%10,x%100/10,x/100%10,x/1000);}
	else if(x>=10000&&x<=99999){
		printf("5\n");
		printf("%d %d %d %d %d\n",x/10000,x/1000%10,x/100%10,x%100/10,x%100%10);
	感觉我是最麻烦的
2020-02-07 11:34:59
这玩意有bug请尝试无脑方法
#include<stdio.h>
main(){
    int a;
    scanf("%d",&a);
    printf("5\n");
   printf("1 2 3 4 5\n");
   printf("54321");
    

}
2020-01-08 22:22:04
不考虑数组,直接硬上,简单粗暴
 int num, countNum = 0,num1 = 0,num2 = 0;
            int i,j;
            cin >> num;
            while(num != 0)
            {
                i = num % 10;
                j = num / 10;
                num = j;
                countNum++;
                num1+=i;
                num1*=10;
            }
            cout << countNum << endl;
            num1/=10;
            num2 = num1;
            while(num2 != 0){

                i = num2 % 10;
                j = num2 / 10;
                num2 = j;
                cout << i << ' ';
            }
            cout << endl
2019-11-27 21:55:49
#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;
}
2019-11-20 22:23:47
你们这也太复杂了吧  看看我的#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;
	

}
2019-11-20 21:08:35
#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;

}
2019-11-10 22:13:46
#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
2019-11-08 08:00:36
#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;
}
2019-11-02 11:30:56