Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
2 / 2 / 1
Регистрация: 18.01.2022
Сообщений: 42

Сумма цифр

07.02.2022, 21:12. Показов 1431. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На бумаге выписаны числа от 1 до N по порядку. Между каждой парой соседних цифр попеременно расставлены знаки + и -. Найти чему равно значение этого выражения.
Например, пусть N=12, тогда нетрудно проверить, что сумма равна пяти.
+1 -2 +3 -4 +5 -6 +7 -8 +9 -1+0 -1+1 -1+2 = 5

Формат входного файла:

Первая строка входного файла содержит целое число N (1 ≤ N ≤ 1015).

Формат выходного файла:

Первая строка выходного файла должна содержать значение суммы, определенной в условии задач
ОГРАНИЧЕНИЕ ВРЕМЕНИ 1 СЕКУНДА
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.02.2022, 21:12
Ответы с готовыми решениями:

У четырехзначного числа сумма цифр равна 12, а сумма квадратов цифр равна 62, найти такие числа
У четырехзначного числа сумма цифр равна 12, а сумма квадратов цифр равна 62. Найти такие числа

число а лучше б, если сумма цифр а больше суммы цифр числа б, а в случае равенства сумм цифр, если число а мен
Программа должна быть написана с помощью вложенных циклов.число а лучше б, если сумма цифр а больше суммы цифр числа б, а в случае...

Найти количество четырехзначных чисел, у которых сумма крайних цифр в 2 раза больше суммы средних цифр
Найти количество четырехзначных чисел, у которых сумма крайних цифр в 2 раза больше суммы средних цифр, а сами числа кратны 3. Напишите...

20
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
07.02.2022, 23:03
Цитата Сообщение от MaFFFuH Посмотреть сообщение
Первая строка входного файла содержит целое число N (1 ≤ N ≤ 1015).
И всё? А сами N чисел откуда брать? Создать ИИ который поработит человечество (чтоб не мешали), найдёт ту самую абстрактную бумажку и прочтёт с неё N чисел?
Pascal
1
2
3
4
5
6
7
## Reset(input, 'inp.txt');
Rewrite(output, 'otp.txt');
var c := ReadlnInteger;
var s := ReadString;
var (res,ind) := (0,1);
loop c do res += ReadIntegerFromString(s, ind);
res.Println;
1
 Аватар для canadamoscow
1179 / 430 / 194
Регистрация: 23.03.2020
Сообщений: 1,021
Записей в блоге: 1
07.02.2022, 23:22
Pascal
1
2
## var n := ReadAllText('input.txt').ToInteger;
WriteAllText('output.txt', (n.IsEven ? '-' : '') + ((n+1) div 2))
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
08.02.2022, 11:18
Pascal
1
## 1.to(readinteger).joinintostring('').select((c,i)->i.isodd?-strtoint(c):+strtoint(c)).sum.print
Добавлено через 59 секунд
Цитата Сообщение от Sun Serega Посмотреть сообщение
А сами N чисел откуда брать?
А они из N получаются!
0
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,380
08.02.2022, 12:07
Цитата Сообщение от MaFFFuH Посмотреть сообщение
N (1 ≤ N ≤ 1015).
уверен, что в задании https://www.cyberforum.ru/cgi-bin/latex.cgi?{10}^{15}, поэтому стандартные типы данных отпадают и задачка перестаёт быть такой уж банальной.
0
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 16:35
Цитата Сообщение от mr-Crocodile Посмотреть сообщение
1015
Исправил.
1
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
08.02.2022, 16:54
mr-Crocodile, ну да!
Нужно ReadInt64

… ну а с алгоритмом — это да! нужно как-то упростить.
В лоб — слишком много цифр обрабатывать.
1
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 17:09
canadamoscow, нигде не сказано, что во входном файле ровно одна строка.
Для файла:
Pascal
1
2
3
##
  var n := ReadAllLines('input.txt')[0].ToInteger;
  WriteAllText('output.txt', (1 - n * (n - 1) div 2).ToString)
Для консоли:
Pascal
1
2
3
##
  var n := ReadInteger;
  (1 - n * (n - 1) div 2).Print
0
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,380
08.02.2022, 17:15
Цитата Сообщение от MaFFFuH Посмотреть сообщение
Найти чему равно значение этого выражения.
Например, пусть N=12, тогда нетрудно проверить, что сумма равна пяти.
+1 -2 +3 -4 +5 -6 +7 -8 +9 -1+0 -1+1 -1+2 = 5
Cyborg Drone, Вы точно решаете именно эту задачу?
Цитата Сообщение от Cyborg Drone Посмотреть сообщение
Pascal
1
2
3
##
  var n := ReadInteger;
  (1 - n * (n - 1) div 2).Print
Code
1
2
12
-65
1
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 17:46
mr-Crocodile, спасибо.

Внимание! мой ответ в сообщении #8 неверный!

Мне что-то показалось, что это сумма арифметической прогрессии из n элементов с a1=1 и d=-1. И с диапазоном чисел я тоже ошибся.

Исправленная программа:
Pascal
1
2
3
4
5
##
  Reset(input, 'input.txt');
  Rewrite(output, 'output.txt');
  var n := ReadInt64;
  (n div 2 - n mod 2 * n).ToString.Print
или
Pascal
5
  (n shr 1 - n and 1 * n).ToString.Print
Для консольного варианта убрать строки 2 и 3, и .ToString из строки 5.
0
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
08.02.2022, 18:26
Нет, для N=12 сумма всё ещё 6 а не 5.
И + если сделать for var n видно что знак обратный ожидаемому.

Из за того что задача просит использовать отдельные цифры чисел - посчитать одном выражением не выйдет.
Для чисел с чётным и нечётным кол-вом цифр формулы вообще разные.

И кстати для чего вообще .ToString перед .Print?
Независимо от консольности - он ничего не делает.
0
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 18:33
А, вот ведь моя невнимательность! Знаки расставлены не между числами, а между цифрами!

Получается, что мой ответ в сообщении #10 тоже неверный.
0
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
08.02.2022, 18:40
Ну да, я тоже на этом изначально попался... Слишком привык к обычным школьным задачкам.

Думаю стоит начать с того что для каждого первого числа из k цифр - перед ним было нечётное кол-во цифр:
Pascal
1
2
3
4
5
6
7
##
(1..9).JoinToString('').Length.Println;
(1..99).JoinToString('').Length.Println;
(1..999).JoinToString('').Length.Println;
(1..9999).JoinToString('').Length.Println;
(1..99999).JoinToString('').Length.Println;
(1..999999).JoinToString('').Length.Println;
(формулами тоже просто, но так нагляднее)

То есть для обобщения последовательность можно представить как:
Code
1
2
3
4
-0+1-2+3-...
-10+11-12+13-...
-100+101-102+103-...
-1000+1001-1002+1003-...
Так должно быть возможно решить задачу всего даже одним циклом, проходящим по отдельным цифрам числа n, со (скорее всего) нереально сложной формулой внутри.
0
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 18:41
Цитата Сообщение от Sun Serega Посмотреть сообщение
для чего вообще .ToString перед .Print?
А без .ToString специализированный файл не получится? Хотя, если использовать .PrintLn, то должен получиться текстовый файл.
0
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
08.02.2022, 18:44
Не знаю что вы имеете в виду под
Цитата Сообщение от Cyborg Drone Посмотреть сообщение
специализированный файл
Типизированный файл, что ли? Но переменная output это текстовый файл, его никак по-другому и не откроешь. Не зависимо от того, что использовали для вывода.
0
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,450
08.02.2022, 19:05
Типизированный, конечно. Опечатался.

И что-то я сегодня совсем невнимательный... Консоль перенаправляется на текстовые файлы.
0
 Аватар для XzzzX
405 / 280 / 120
Регистрация: 09.07.2021
Сообщений: 1,016
Записей в блоге: 1
08.02.2022, 19:38
Вообще тут есть некоторые закономерности.
Например
Code
1
2
3
4
5
12 -> 5
13 -> 7
14 -> 10
15 -> 14
16 -> 19
и всё бы хорошо, но
Code
1
2
3
4
19 -> 40
20 -> 38
20 -> 38
21 -> 37
затем всё начинается сначала
Code
1
2
3
4
5
22 -> 37
23 -> 38
24 -> 40
25 -> 43
26 -> 47
сколько ещё таких сюрпризов наверно не предугадать
0
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
08.02.2022, 19:54
Лучше посмотрите на эту закономерность:
Pascal
1
2
3
4
5
6
7
8
9
## function f(r: IntRange) := r.JoinToString('').Select((d,i)->i.IsEven?-d.ToDigit:+d.ToDigit).Sum;
 
var t := 1;
loop 8 do
begin
  var r := (0..t-1);
  Print(r); f(r).Println;
  t *= 10;
end;
Формулу легко вывести через геометрическую прогрессию.

Остаётся посчитать остальные цифры, от 99...99999 до N.
Как я и сказал выше, первая цифра первого числа после этой кучи девяток будет иметь перед собой минус.

Для N с чётным кол-вом цифр всё оносительно просто:
Code
1
2
3
4
5
6
7
8
-1+0
-1+1
-1+2
-1+3
...
-3+0
-3+1
...
То есть знак цифры определяется её местом в числе (еденицы/десятки/сотки и т.д.). Тогда можно разложить на 3 шага:
Code
1
2
3
4
f(0..35) =
    +f(0..9) = +5
    +f(10..29) = -(1..2).sum*10 + 2*(0..9).sum
    +f(30..35) = -3*(5+1) + (0..5).sum
Для N с нечётным кол-вом цифр чуть сложнее. Там знаки цифр чередуются:
Code
1
2
3
4
5
6
7
-1+0-0
+1-0+1
-1+0-2
+1-0+3
...
-2+0-0
+2-0+1
То есть как я и сказал, надо 2 алгоритма, для N с чётным и нечётным кол-вом цифр.
Пока пытаюсь для нечётных обобщить, но чот мозги кипят.
0
 Аватар для XzzzX
405 / 280 / 120
Регистрация: 09.07.2021
Сообщений: 1,016
Записей в блоге: 1
08.02.2022, 19:54
Цитата Сообщение от XzzzX Посмотреть сообщение
сколько ещё таких сюрпризов наверно не предугадать
хотя видимо это связано с тем, что число круглое. сразу не заметил почему-то. но выборка всё равно мала, что бы быть в чём-то уверенным
0
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
08.02.2022, 21:22
Вроде так для N с нечётным кол-во цифр:
Code
1
2
3
4
5
6
7
8
9
10
f(0..35) =
    +f(0..9) = +5
    +f(10..29) = -(1..2).sum*10 + 2*(0..9).sum
    +f(30..35) = -3*(5+1) + (0..5).sum
 
f(0..3579) =
    +f(0..999) = +410
    +f(1000..2999) = -(1..2).sum*10*10*10 + 2*(0..9).sum*10*10 - 2*10*(0..9).sum*10 + 2*10*10*(0..9).sum
        =100 * ( -(1..2).sum + 2*(0..9).sum )
    +f(3000..3579) = -3*(579+1) + (0..579).sum
А для обратного случая на самом деле даже проще, потому что все цифры кроме последней сокращаются:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
-1+0-0
+1-0+1
-1+0-2
+1-0+3
-1+0-4
+1-0+5
...
-1+1-0
+1-1+1
-1+1-2
+1-1+3
-1+1-4
+1-1+5
...
-2+0-0
+2-0+1
-2+0-2
+2-0+3
-2+0-4
+2-0+5
Таким образом:
Code
1
2
3
4
5
6
7
8
9
f(0..468) =
    +f(0..99) = -40
    +f(100..459) = (460-100)/10 * f(0..9)
    +f(460..468) = f(0..8) + коррекция не сокращённого числа[ -4+6 ]
 
f(0..45678) =
    +f(0..9999) = -4090
    +f(10000..45669) = (45670-10000)/10 * f(0..9)
    +f(45670..45678) = f(0..8) + коррекция не сокращённого числа[ -4+5-6+7 ]
Однако выразить f(0..куча_девяток) геометрической прогрессией не так просто как мне показалось изначально:
Code
1
2
3
4
5
6
7
8
f(0..9) = 5
f(0..99) = -40
f(0..999) = 410
f(0..9999) = -4090
f(0..99999) = 40910
f(0..999999) = -409090
f(0..9999999) = 4090910
f(0..99999999) = -40909090
Наверное лучше попробовать выразить как частный случай f для меньшего кол-ва цифр.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.02.2022, 21:22
Помогаю со студенческими работами здесь

Найти все трехзначные натуральные числа, сумма цифр которых равна В, а само число состоит из разных цифр
Найти все трехзначные натуральные числа, сумма цифр которых равна В, а само число состоит из разных цифр.

Определить, равна ли сумма первых двух цифр натурального числа сумме последних двух цифр
Определить, равна ли сумма первых двух цифр натурального числа сумме последних двух цифр. Решать с помощью STR и VAL.

Сумма цифр заданного четырёхзначного числа N превосходит произведение цифр этого же числа на 1
Сумма цифр заданного четырёхзначного числа N превосходит произведение цифр этого же числа на 1.

Наибольшая сумма цифр
Дано два двухзначный числа. Найти число, у которого сумма цифр больше. Если сумма цифр этих чисел одинаковая, то вывести большее из...

Строка. Количество и сумма цифр
Найти количество цифр в строке и сумму этих цифр.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru