Как вы проверяете, делится ли число на другое число (Python)?
Мне нужно проверить, является ли каждое число от 1 до 1000 кратным 3 или кратным 5. Я думал, что сделаю это, разделив число на 3, и если результат будет целым числом, то оно будет кратным 3. То же самое с 5.
Как проверить, является ли число целым числом?
вот мой текущий код:
n = 0
s = 0
while (n < 1001):
x = n/3
if isinstance(x, (int, long)):
print 'Multiple of 3!'
s = s + n
if False:
y = n/5
if isinstance(y, (int, long)):
s = s + n
print 'Number: '
print n
print 'Sum:'
print s
n = n + 1
9 ответов
Вы делаете это с помощью модуля оператора %
n % k == 0
оценивает true тогда и только тогда, когда n
- точно кратно k
. В элементарной математике это называется остатком от деления.
в вашем текущем подходе вы выполняете деление, и результат будет либо
- всегда целое число, если вы используете целочисленное деление или
- всегда поплавок, если вы используете плавающую точку деление.
это просто неправильный способ проверить делимость.
вы можете просто использовать %
оператор модуля для проверки делимости.
Например: n % 2 == 0
означает, что n точно делится на 2 и n % 2 != 0
означает, что n не делится точно на 2.
можно использовать % оператора чтобы проверить divisiblity заданного числа
код, чтобы проверить ли нет. делится на 3 или 5 когда нет. менее 1000 приведено ниже:
n=0
while n<1000:
if n%3==0 or n%5==0:
print n,'is multiple of 3 or 5'
n=n+1
этот код, похоже, делает то, что вы просите.
for value in range(1,1000):
if value % 3 == 0 or value % 5 == 0:
print(value)
или что-то вроде
for value in range(1,1000):
if value % 3 == 0 or value % 5 == 0:
some_list.append(value)
или любое количество вещей.
У меня был такой же подход. Потому что я не понимал, как использовать оператор module (%).
6 % 3 = 0 *Это означает, что если разделить 6 на 3, у вас не будет остатка, 3-Фактор 6.
теперь вы должны связать его с вашей данной проблемой.
если n % 3 == 0 *Это означает, что если мое число (n) делится на 3, оставляя 0 остатков.
добавьте свой оператор then (print, return) и продолжите свой
для малых чисел n%3 == 0
будет хорошо. Для очень больших чисел я предлагаю сначала вычислить перекрестную сумму, а затем проверить, является ли перекрестная сумма кратной 3:
def is_divisible_by_3(number):
if sum(map(int, str(number))) % 3 != 0:
my_bool = False
return my_bool
попробуйте это ...
public class Solution {
public static void main(String[] args) {
long t = 1000;
long sum = 0;
for(int i = 1; i<t; i++){
if(i%3 == 0 || i%5 == 0){
sum = sum + i;
}
}
System.out.println(sum);
}
}
jinja2 шаблон fizzbuz:
<form>
<ol>
{% for x in range(1,n+1) %}
{% set fizzbuzz_rpm = x %}
{% if x % 3 == 0 and x % 5 == 0 %}
{% set fizzbuzz_rpm="FizzBuzz" %}
{% elif x % 3 == 0 %}
{% set fizzbuzz_rpm="Fizz" %}
{% elif x %5 == 0 %}
{% set fizzbuzz_rpm="Buzz" %}
{% endif %}
<li>{{fizzbuzz_rpm}}</li>
{% endfor %}
</ol>
</form>
самый простой способ-проверить, является ли число целое число int(x) == x
. Иначе, что сказал Дэвид Хеффернан.