题目描述: 输出1 n中能被3整除,且至少有一位数字是5的所有整数. 输入格式: 输
时间: 2023-12-15 10:02:39 浏览: 185
题目要求输出1到n之间能被3整除且至少有一位数字是5的所有整数。
首先,我们需要判断一个整数是否能被3整除。我们可以利用整数的特性,即一个整数被3整除,其各位数字之和也能被3整除。因此,我们遍历1到n之间的每个整数,对每个数求各位数字的和,然后判断该和是否能被3整除。
其次,我们需要判断一个整数是否至少有一位是5。我们可以将整数转化为字符串,然后检查字符串中是否包含字符'5'。
综上所述,我们可以使用以下算法来解决这个问题:
1. 输入整数n。
2. 初始化一个空列表result,用于存储满足条件的整数。
3. 遍历1到n之间的每一个整数i。
- 将i转化为字符串。
- 如果字符串中包含字符'5'并且i能被3整除,则将i添加到result列表中。
4. 输出result列表。
下面是一个具体的例子来演示算法的运行过程:
假设n为20。
1. 输入整数n:20。
2. 初始化一个空列表result,result = []。
3. 遍历1到20之间的每一个整数i:
- 当i为1时,将1转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为2时,将2转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为3时,将3转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为4时,将4转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为5时,将5转化为字符串,字符串中包含字符'5',将5添加到result列表中。
- 当i为6时,将6转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为7时,将7转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为8时,将8转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为9时,将9转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为10时,将10转化为字符串,字符串中包含字符'5',跳过此次循环。
- 当i为11时,将11转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为12时,将12转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为13时,将13转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为14时,将14转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为15时,将15转化为字符串,字符串中包含字符'5',将15添加到result列表中。
- 当i为16时,将16转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为17时,将17转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为18时,将18转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为19时,将19转化为字符串,字符串中不包含字符'5',跳过此次循环。
- 当i为20时,将20转化为字符串,字符串中不包含字符'5',跳过此次循环。
4. 输出result列表:[5, 15]。
所以,当输入为20时,输出为[5, 15]。
阅读全文