HDU1013一个简单的数学题

本文探讨了求解一个数的个位数字之和,直至得到一位数的方法。介绍了两种实现方式:一种是通过累加各位数字并不断取余得到结果;另一种是基于数位和的规律,找到循环数序列的特性。通过代码示例展示了这两种方法,并强调了解决问题时的思维锻炼。
部署运行你感兴趣的模型镜像

题意是:求一个数的个位数字之和 一直加到只有一位数 输出

两种方法:

1、求各位之和,然后,不断取余,得到一位数

2、找规律,发现要输出的结果 是长度为9的循环数即:

1 2 3 4 5 .....9 10 11 12 13 14.....19 20 21 22 ....

12 3 4 5 ..... 9 1 2 3 4 5 .....1 2 3 4 .....

#include<iostream>//方法1
#include<string>
using namespace std;
int main()
{
	string  str;
	while(cin>>str&&str[0]!='0')
	{
		int sum=0;
		for(int i=0;i<str.length();i++)
		{
			sum+=str[i]-'0';
		}
		while(sum>=10)
		{
			int n=sum%10;
			sum=sum/10+n;
		}
		cout<<sum<<endl;
	}
	return 0;
}

方法2:sum-1后面又+1是为了解决9N的问题

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string  str;
	while(cin>>str&&str[0]!='0')
	{
		int sum=0;
		for(int i=0;i<str.length();i++)
		{
			sum+=str[i]-'0';
		}
		cout<<(sum-1)%9+1<<endl;
	}
	return 0;
}


由此想到的,一般的题目,要多思考,锻炼自己的思维

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值