反置数

问题描述:
一个整数的“反置数”指的是把该整数的每一位 数字的顺序颠倒过来所得到的另一个整数。如果一个整数的末尾是以0结尾,那么在它的反置数当中,这些0就被省略掉了。比如说,1245的反置数是 5421,而1200的反置数是21。请编写一个程序,输入两个整数,然后计算这两个整数的反置数之和sum,然后再把sum的反置数打印出来。要求:由 于在本题中需要多次去计算一个整数的反置数,因此必须把这部分代码抽象为一个函数的形式。

输入格式:
输入只有一行,包括两个整数,中间用空格隔开。

输出格式:
输出只有一行,即相应的结果。

输入输出样例:
样例输入:
435 754

样例输出:
199

c语言解法:

#include <stdio.h>
#include <string.h>

int n,m;
int a[11];

int opposite(int x)
{
	memset(a,0,sizeof(a));
	int i=0,count=0;
	while(x!=0)
	{
		a[i++]=x%10;
		count++;
		x=x/10;
	}
	
	int sum=0;
	for(i=0;i<count;i++)
	 sum=10*sum+a[i];
	
	return sum;
}

int main()
{
	scanf("%d%d",&n,&m);
	
	int t1=opposite(n);
	int t2=opposite(m);
	
	int sum=t1+t2;
	sum=opposite(sum);
	
	printf("%d",sum);
	return 0;
}

java解法:

import java.util.Scanner;

public class Opposite {
	private static int opp(int x)
	{
		int [] arr=new int[11];
		int i=0,count=0;
		while(x!=0)
	   {
			arr[i++]=x%10;
			count++;
			x=x/10;
		}
		
		int sum=0;
		for(i=0;i<count;i++)
		 sum=sum*10+arr[i];
		return sum;
	}
	
	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();
		int m=sc.nextInt();
		
		int t1=opp(n);
		int t2=opp(m);
		
		int sum=t1+t2;
		sum=opp(sum);
		
		System.out.println(sum);
	}
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值