bambula4000 / Ввод данных через for.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’ |
По данному натуральному n ≤ 9 выведите лесенку из n ступенек, i-я ступенька |
состоит из чисел от 1 до i без пробелов. |
»’ |
n = int ( input ()) |
for i in range ( 1 , n + 1 ): |
for x in range ( 1 , i + 1 ): |
print ( x , end = » ) |
print () |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
#input(‘Enter: ‘) |
lis = [] |
for x in input ( ‘Enter a number: ‘ ). split ( ‘ ‘ ): |
lis . append ( x ) |
if ( lis [ 0 ] + lis [ 1 ]) % 2 != ( lis [ 2 ] + lis [ 3 ]) % 2 : |
print ( ‘NO’ ) |
else : |
print ( ‘YES’ ) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’ |
Дано N чисел: сначала вводится число N, затем вводится ровно N целых чисел. |
Подсчитайте количество нулей среди введенных чисел и выведите это количество. |
Вам нужно подсчитать количество чисел, равных нулю, а не количество цифр. |
»’ |
n = int ( input ()) |
sum = 0 |
for i in range ( 1 , n + 1 ): |
x = int ( input ()) |
if x == 0 : |
sum += 1 |
print ( sum ) |
»’ ИЛИ |
num_zeroes = 0 |
for i in range(int(input())): |
if int(input()) == 0: |
num_zeroes += 1 |
print(num_zeroes) |
»’ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’ |
Для настольной игры используются карточки с номерами от 1 до N. Одна карточка |
потерялась. Найдите ее, зная номера оставшихся карточек. |
Дано число N, далее N − 1 номер оставшихся карточек (различные числа от 1 до |
N). Программа должна вывести номер потерянной карточки. |
Для самых умных: массивами и аналогичными структурами данных пользоваться нельзя. |
»’ |
n = int ( input ()) |
sum = 0 |
for i in range ( 1 , n + 1 ): |
sum += i |
for i in range ( 1 , n ): |
sum -= int ( input ()) |
print ( sum ) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’ |
Условие |
Дано несколько чисел. Вычислите их сумму. Сначала вводите количество чисел N, |
затем вводится ровно N целых чисел. Какое наименьшее число переменных нужно |
для решения этой задачи? |
»’ |
n = int ( input ()) |
sum = 0 |
for i in range ( n ): |
i = int ( input ()) |
sum += i |
print ( sum ) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’По данному натуральному n вычислите сумму 13+23+33+. +n3.»’ |
n = int ( input ()) |
x = 0 |
for i in range ( 1 , n + 1 ): |
x += i ** 3 |
print ( x ) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
»’ |
По данному натуральном n вычислите сумму 1!+2!+3!+. +n!. В решении этой |
задачи можно использовать только один цикл. Пользоваться математической |
библиотекой math в этой задаче запрещено. |
»’ |
n = int ( input ()) |
x = 1 #считаем сумму факториала |
sum = 0 # сохраняем в сумму фаториал каждого числа |
for i in range ( 1 , n + 1 ): |
x *= i # итоговое значение будет факториал числа N |
sum += x # сохраняем промежуточный факториал каждого прохода цикла |
print ( sum ) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
Источник
Программа для нахождения количества цифр в числе
Описание задачи
Программа принимает число и выводит количество цифр в нем.
Решение задачи
- Берем значение целого числа и записываем его в переменную.
- Используем цикл while и при помощи оператора целочисленного деления «уничтожаем» каждую цифру числа начиная с последней, а при каждой итерации цикла специально созданную переменную (так называемый счетчик цикла) увеличиваем на единицу. После того как введенное в начале число станет равным 0, цикл прекратит свою работу.
- Выводим значение этого счетчика на экран.
- Конец.
Исходный код
Ниже дан исходный код для подсчета количества цифр в данном числе. Результаты работы программы также даны ниже.
Объяснение работы программы
- Записываем введенное пользователем число в переменную n .
- Задаем переменную count и инициируем ее значением 0.
- Используем цикл while и при помощи оператора целочисленного деления «уничтожаем» каждую цифру числа начиная с конца.
- При каждой итерации цикла переменная count увеличивается на 1.
- Как только цифры в числе заканчиваются и число n становится равным 0, цикл прекращает свою работу.
- Выводим переменную count на экран.
Результаты работы программы
Примечание переводчика
Надо заметить, что опять эту задачу можно решить намного короче, если использовать методы строк.
Здесь введенное число принимается как строка и мы просто выводим ее длину.
Источник
Решение задач на С++
понедельник, 14 февраля 2011 г.
Операторы цикла
Цикл For. Блок 2. Задачи на цикл For.
Задача A. Четные числа
Выведите (через пробел) все четные числа от a до b (включительно).
- int a, b ;
- cin >> a >> b;
- for ( int i = a; i if (i % 2 == 0)
- cout ‘ ‘ ;
* This source code was highlighted with Source Code Highlighter .
Задача B. Остаток
Вводятся 4 числа: a, b, c и d.
Выведите все числа на отрезке от a до b, дающие остаток c при делении на d.
- int a, b, c, d ;
- cin >> a >> b >> c >> d;
- for ( int i = a ; i if (i % d == c)
- cout ‘ ‘ ;
* This source code was highlighted with Source Code Highlighter .
Задача C. Квадраты
Выведите все числа на отрезке от a до b, являющиеся полными квадратами.
- int a , b;
- cin >> a >> b ;
- int sqrt_a = ceil(sqrt(a + 0.0));
- int sqrt_b = sqrt(( double )b);
- for ( int i = sqrt_a ; i » » ;
* This source code was highlighted with Source Code Highlighter .
В этом случае мы рационально движемся от sqrt(a) к sqrt(b), т.к. проверка меньших и больших значений смысла не имеет.
Нужно обратить внимание, что корень от а округляется в большую сторону ceil(sqrt(a + 0.0) перед отправкой в цикл: если а – и есть полный квадрат, то это число также должно быть выведено, однако, если а дает дробный корень, то его целая часть (при приведении к типу int) даст заведомо меньший квадрат, чем значение а. Поэтому мы заранее округляем sqrt(a) до следующего целого числа, дабы избежать выведение лишнего квадрата.
Варинат 2.
Этот вариант реализации менее рациональный, однако более прозрачный. Мы напрямую движемся от а до b c проверкой полноты квадрата каждого из текущих значений.
Задача H. Делители числа
Выведите все натуральные делители числа x в порядке возрастания (включая 1 и само число).
- int x;
- cin >> x;
- for ( int i = 1 ; i if ( x % i == 0 )
- cout ‘ ‘ ;
* This source code was highlighted with Source Code Highlighter .
Задача I. Количество делителей
Подсчитайте количество натуральных делителей числа x (включая 1 и само число; x
- int x, k = 0;
- cin >> x;
- for ( int i = 1; i if (x % i == 0 )
- k++;
- cout * This source code was highlighted with Source Code Highlighter .
Задача J. Сумма ста
Вычислите сумму данных 100 натуральных чисел. Вводятся 100 чисел, сумму которых необходимо посчитать.
- int x;
- long long sum = 0;
- for ( int i = 1; i > x;
- sum += x;
- >
- cout * This source code was highlighted with Source Code Highlighter .
Задача K. Сумма чисел
Вычислите сумму данных N натуральных чисел. Вводится число N, а затем N чисел, сумму которых необходимо вычислить.
- int n, x;
- long long sum = 0;
- cin >> n;
- for ( int i = 1; i > x;
- sum += x;
- >
- cout * This source code was highlighted with Source Code Highlighter .
Задача M. Нули
Вводится число N, а затем N чисел. Подсчитайте, сколько среди данных N чисел нулей.
Задача N. Подсчет чисел
Подсчитайте, сколько среди данных N чисел нулей, положительных чисел, отрицательных чисел. Вводится число N, а затем N чисел. Необходимо вывести сначала число нулей, затем число положительных и отрицательных чисел.
- int n, x;
- int zero = 0, pos = 0, neg = 0;
- cin >> n;
- for ( int i = 1; i > x;
- if (x == 0) zero++;
- else if (x > 0) pos++;
- else neg++;
- >
- cout ‘ ‘ * This source code was highlighted with Source Code Highlighter .
При данной реализации мы каждый раз в цикле прогоняем последовательную проверку числа на знак. Сейчас это не доставляет никаких неудобств, т.к. мы имеем всего 3 критерия подсчета. Однако, если б требовалась более широкая проверка, например, относительно 10-ти различных случаев, то рациональнее было бы использовать сase–структуру. Что и сделано в варианте 2
Вариант 2.
Используем сase–структуру для определения знака, предварительно нормировав ненулевые значения в единицу (1/-1).
Задача O. Ноль или не ноль
Проверьте, есть ли среди данных N чисел нули. Вводится число N, а затем N чисел. Выведите YES, если среди введенных чисел есть хотя бы один нуль, или NO в противном случае.
This source code was highlighted with Source Code Highlighter .
Вариант 2.
Ту же самую идею можно описать короче.
- int x, n;
- cin >> n;
- bool zeroExist = false ;
- for ( int i = 1; i > x;
- zeroExist = zeroExist | (x == 0);
- if (zeroExist)
- break ;
- >
- cout «YES» : «NO» );
* This source code was highlighted with Source Code Highlighter .
Задача P. Уравнение по возрастанию
Вводятся 4 числа: a, b, c и d.
Найдите все целые решения уравнения ax 3 + bx 2 + cx + d = 0 на отрезке [0,1000] и выведите их в порядке возрастания.
- long long a , b , c , d ;
- cin >> a >> b >> c >> d;
- for ( int i = 0; i if ( a*i*i*i + b*i*i + c*i + d == 0)
- cout ‘ ‘ ;
* This source code was highlighted with Source Code Highlighter .
Задача Q. Уравнение по убыванию
Вводятся 4 числа: a, b, c и d.
Найдите все целые решения уравнения ax 3 + bx 2 + cx + d = 0 на отрезке [0,1000] и выведите их в порядке убывания.
- long long a, b, c, d;
- cin >> a >> b >> c >> d;
- for ( int i = 1000; i >= 0; i—)
- if (a*i*i*i + b*i*i + c*i + d == 0)
- cout ‘ ‘ ;
* This source code was highlighted with Source Code Highlighter .
Задача R. Количество решений
Вводятся 5 чисел: a, b, c, d и e.
Найдите все целые решения уравнения ( ax 3 + bx 2 + cx + d ) / ( x — e ) = 0 на отрезке [0,1000] и выведите их количество.
- long long a, b, c, d, e;
- cin >> a >> b >> c >> d >> e ;
- int k = 0;
- for ( int i = 0; i if (a*i*i*i + b*i*i + c*i + d == 0)
- if (i — e != 0)
- k++;
- cout * This source code was highlighted with Source Code Highlighter .
Задача S. ГНЧЭ-1
«ГНЧЭ-1» – сложное электронное устройство, выдающее каждую секунду очередное число последовательности 1, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5. Ввиду дороговизны электронных комплектующих вам поручено разработать эмулятор для этого устройства.
Дано количество секунд (от 1 до 1000000), которые работает генератор после включения. Вывести результат работы генератора
Вариант 1.
При таком варианте реализации мы печатаем столько раз текущее значение cur сколько оно само обозначает count , после чего обнуляем подсчет одинаковых выводов count и переходим на следующее текущее значение cur и т.д.
Вариант 2.
В этом варианте решения идея та же. Однако контроль за количеством отработанных секунд и количеством напечатанных текущих значений возложены на два отдельных цикла.
Итак, здесь мы ведем подсчет напечатанных позиций pos , которых должно быть ровно столько же, сколько секунд работает машина. А внутренним циклом задаем печать текущего числа cur . Проверка условия if (pos == n) не даст задержаться во внутреннем цикле дольше положенных секунд.
- int n;
- cin >> n;
- int pos = 0, cur = 1;
- for ( ; pos for ( int i = 0; i «%d » , cur);
- pos++;
- if (pos == n)
- break ;
- >
- cur++;
- >
* This source code was highlighted with Source Code Highlighter .
Источник