//PascalABC.NET
//В задаче есть ограничение по времени в 1 секунду
//поэтому была использована функция milliseconds
//которая возвращает кол-во миллисекунд с момента
//начала работы программы
var
N, cur, count: uint64;
begin
read(N);
cur := 1;
count := 0;
while (cur <> 0) and (milliseconds() / 1000 < 0.78) do
begin
cur := (cur * 10 + 1) mod N;
count := count + 1;
end;
if (cur = 0) then write('1' * (count = 1 ? count : count + 1))
else write('NO');
end.
10- это точно, так как присвоено
рандом(5) - это значит что У от 0 до 4
т.е. У может принимать значения от 10 до 14
1 завдання A,B,AB,O правильна відповідь
def func1(arr)
arr.select { |item| (100..999).cover?(item) && (item / 100 == item % 10) }
end
def func2(arr)
arr.count { |item| (item % 3).zero? && (item % 10 != 5) }
end
def func3(arr)
sum = 0
arr.each { |x| sum += x if x.even? && (10..99).cover?(x) }
sum
end
def func4(arr)
narr = []
arr.each { |x| narr.push(x) if (100..200).cover?(x) }
narr.empty? ? (arr.map { |x| x = 1 }) : narr
end
arr = Array.new(rand(2..1000))
arr.map! { |item| item = rand(0...2000) }
puts 'Исходный массив:'
puts arr
puts "\n1. Найти и вывести на экран все трехзначные числа,в которых на первом и последнем месте стоят одинаковые цифры: "
puts func1(arr)
puts "\n2. Подсчитать количество чисел,кратных 3 и не оканчивающихся на 5 и вывести на экран: "
puts func2(arr)
puts "\n3. Найти сумму всех двузначных четных чисел и вывести на экран: "
puts func3(arr)
puts "\n4. Найти в массиве числа из диапазона от 100 до 200 включительно и вывести на экран,если таких нет,то заменить все числа на 1 и вывести на экран:"
puts func4(arr)
8=i^2, значит 1 символ весит 3бита
3*32=96бит