不变初心数
描述
不变初心数是指这样一种特别的数,它分别乘 2、3、4、5、6、7、8、9 时,所得乘积各位数之和却不变(等于该数的各位数字之和)。
例如 18 就是这样的数:18 的 2 倍是 36,3+6=9;18 的 3 倍是 54,5+4=9;…… 18 的 9 倍是 162,1+6+2=9。
对于 18 而言,9 就是它的初心。
编写程序,输出指定范围内[ a, b ] 的所有不变初心数。
输入
一行中给出2个正整数a和b,且 a <= b <= 10^5。
输出
按照从小到大的顺序输出每个不变初心数,每行一个,每个不变初心数的输出格式为:不变初心数(初心)。
如果在[ a, b ] 不存在不变初心数,则输出:None。
输入样例 1
10 100
输出样例 1
18(9)
45(9)
90(9)
99(18)
以下是编程部分:
要点:
1.我自己实现了两个函数sdi(自创的整数各位数的和的缩写)和oas(自创的初心数的缩写)。sdi用于求和整数各位和,返回值为整数,oas用于判断输入的数是否为初心数,返回值为0(假)和1(真)。
2.sdi函数在oas函数之前,因为在oas中用到了sdi函数,所以要考虑顺序。(不过你也可以打乱顺序,只需要在oas中使用sdi之前对其进行声明。这个知识点我就不展开讲了,不了解可以去搜索一下。)
3.在int main()中,定义了一个判断条件的变量judge,用于判断是否输出“None”。
4.小知识点,if(judge)这个判断语句中judge的值为0或1,即代表“假”和“真”这两个状态,if(真)则执行后续语句,反之同理,这是合法的语句。
感谢阅读。_(•̀ω•́ 」∠)_