
Вопрос задан 10.06.2023 в 23:10.
Предмет Информатика.
Спрашивает Сабитова Акмарал.
Phyton срочно пожалуйста Дано ціле число N (>1). Вивести найбільше з цілих чисел K, для яких
сума S = 1 + 2 + … + K буде меншою або дорівнює N, і саму цю суму.

Ответы на вопрос

Отвечает Собко Кирилл.
Асимптотика: что-то типа O(NlogN)
def f(n):
return n * (n + 1) // 2
def bs(n):
left = 0
right = n
while left < right:
mid = (left + right) // 2
now = f(mid)
if now <= n and f(mid + 1) > n:
return mid
if now > n:
right = mid - 1
else:
left = mid + 1
return left
k = bs(int(input()))
print(k, f(k), sep='\n')



Отвечает нейросеть ChatGpt. Будьте внимательны, ответы нейросети могут содержать ошибочные или выдуманные данные.
Ось Python код, який вирішує вашу задачу:
pythondef find_largest_sum(N):
K = 1
S = 0
while S <= N:
S += K
K += 1
return K - 2, S - (K - 2)
# Приклад використання:
N = 15
largest_K, sum_S = find_largest_sum(N)
print("Найбільше число K:", largest_K)
print("Сума S:", sum_S)
Цей код шукає найбільше ціле число K
, для якого сума S = 1 + 2 + ... + K
буде меншою або дорівнює заданому числу N
. У вихідних даних ви отримаєте значення largest_K
, яке є найбільшим числом K
, і sum_S
, яке є відповідною сумою.


Похожие вопросы
Топ вопросов за вчера в категории Информатика
Последние заданные вопросы в категории Информатика
Предметы
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili