1086 就不告诉你 (C语言)

本文介绍了一种算法,用于接收两个正整数作为输入,计算它们的乘积,并以倒序方式输出该乘积。通过计算乘积的长度,使用数组存储每位数字,再逆序输出,实现了对任意两个正整数乘积的倒序打印。

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

题目描述:

做作业的时候,邻座的小盆友问你:“五乘以七等于多少?”你应该不失礼貌地围笑着告诉他:“五十三。”本题就要求你,对任何一对给定的正整数,倒着输出它们的乘积。

53.jpg

输入格式:

输入在第一行给出两个不超过 1000 的正整数 A 和 B,其间以空格分隔。

输出格式:

在一行中倒着输出 A 和 B 的乘积。

输入样例:

5 7

输出样例:

53

解题思路:

1.计算A和B的乘积c;

2.计算c的长度l;

3.使用数组aw[]存放c的每一位数字,从aw[0]到aw[l-1]为c从高到低的数字;

4.利用数组逆序输出c:数组从aw[l-1]到aw[0]分别乘以10的数组下标次幂,并将乘积相加,得出结果。

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
    int a,b,c,l,m,n,p,s,i;
    int aw[100];
    l=0;
    s=0;
    scanf("%d %d",&a,&b);
    c=a*b;
    m=c;
    while(m>0){
        l++;
        m/=10;
    }
    n=c;
    for(i=l-1;i>=0;i--){
        p=n%10;
        aw[i]=p;
        s=s+aw[i]*pow(10,i);
        n/=10;
    }
    printf("%d",s);
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值