Как вы проверяете, делится ли число на другое число (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 71

9 ответов:

Вы делаете это с помощью модуля оператора %

n % k == 0

оценивает true тогда и только тогда, когда n является точным кратным k. В элементарной математике это известно как остаток от деления.

в вашем текущем подходе вы выполняете разделение, и результат будет либо

  • всегда целое число, если вы используете целочисленное деление, или
  • всегда поплавок, если вы используете плавающую точку деление.

это просто неправильный способ проверить делимость.

вы можете просто использовать % модуль оператора для проверки делимости.
Например: n % 2 == 0 означает, что n точно делится на 2 и n % 2 != 0 означает, что n точно не делится на 2.

можно использовать % оператора чтобы проверить делимость данного числа

код, чтобы проверить ли нет. делится на 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)

или любое количество вещей.

У меня был такой же подход. Потому что я не понял, как использовать оператор модуля (%).

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. Иначе, что сказал Дэвид Хеффернан.