Программа на Паскале «Вычисление суммы цифр»
🔁 Использование циклов. Сумма положительных элементов массива. Циклы for, while, repeat. Шесть примеров решения задачи на языке Паскаль. Варианты для Turbo/Borland/FreePascal и PascalABC.NET
Σ Сумма элементов массива. 🔁 Циклы for, while, repeat. Пять примеров решения задачи на языке Паскаль. В некоторых вариантах используется синтаксис для PascalABC.NET
Σ Сумма случайных чисел. 🔁 Циклы for, while. Три задачи на нахождение суммы случайно сгенерированных элементов. Для каждой задачи приведено два варианта — классический синтаксис (Turbo/Borland Pascal) и PascalABC.NET
Задачи по информатике и основам программирования на языке Паскаль. В двух решениях используется оператор целочисленного деления, в двух других — используется преобразование числа к строке и цикл for, последнее решение учитывает рекомендации PascalABC.NET.
Программа «Сумма цифр трёхзначного числа»
Задание:
Введите трёхзначное число. Найдите сумму цифр. Выведите результат на экран.
Program SummaTsifr1;
Var X, Y1, Y2, Y3, Summa : Integer;
begin
writeln(‘Программа вычисления суммы цифр’);
write(‘Введите трёхзначное число X ‘);
readln(X);
Y1 := X div 100;
Y2 := (X — Y1 * 100) div 10;
Y3 := X — Y1 * 100 — Y2 * 10;
Summa := Y1 + Y2 + Y3;
writeln(‘Сумма цифр ‘, Y1:3, Y2:3, Y3:3, ‘ = ‘, Summa: 3)
end.
Замечание:
В процедуре вывода writeln используется форматированный вывод переменной. Например, Y1:3 обозначает, что для вывода значения переменной Y1 будут использоваться три позиции, т.е. в случае однозначного числа, перед ним будет добавлено два пробела, в случае двухзначного числа — добавлен один пробел. При этом если число будет содержать 4 или больше цифр, то оно будет выведено полностью.
Программа «Сумма цифр пятизначного числа»
Задание:
Введите пятизначное число. Найдите сумму цифр. Выведите результат на экран.
Program SummaTsifr2;
Var X, Y1, Y2, Y3, Y4, Y5, Summa : Integer;
begin
writeln(‘Программа вычисления суммы цифр ‘);
write(‘Введите пятизначное число X ‘);
readln(X);
Y1 := X div 10000;
Y2 := (X — Y1 * 10000) div 1000;
Y3 := (X — Y1 * 10000 — Y2 * 1000) div 100;
Y4 := (X — Y1 * 10000 — Y2 * 1000 — Y3 * 100) div 10;
Y5 := X — Y1 * 10000 — Y2 * 1000 — Y3 * 100 — Y4 * 10;
Summa := Y1 + Y2 + Y3 + Y4 + Y5;
writeln(‘Сумма цифр ‘, Summa)
end.
Замечание:
В процедуре вывода writeln используется форматированный вывод переменной. Например, Y1:3 обозначает, что для вывода значения переменной Y1 будут использоваться три позиции, т.е. в случае однозначного числа, перед ним будет добавлено два пробела, в случае двухзначного числа — добавлен один пробел. При этом если число будет содержать 4 или больше цифр, то оно будет выведено полностью.
Тема «Использование цикла for». Программа «Сумма цифр числа»
Задание:
Введите число. Найдите сумму цифр. Для решения задачи используйте цикл for и функции работы со строками. Выведите результат на экран.
Program SumNumbers1;
Var
Y : Array[1..20] of Byte; { Массив для сохранения цифр исходного числа }
Xs : String;
Xr, Summa : Real;
J, N, Err : Integer;
begin
writeln(‘Программа вычисления суммы цифр ‘);
write(‘Введите число X (не более 20 цифр)’);
readln(Xr);
Str(Xr, Xs); { Преобразовать число в строку }
N := Length(Xs); { Вычислить длину строки }
for J := 1 to N do Val(Xs[J], Y[J], Err); { Преобразовать каждый символ строки к числу и записать в массив }
Summa := 0;
for J := 1 to N do Summa := Summa + Y[J];
writeln(‘Сумма цифр ‘, Summa)
end.
Замечание:
procedure Str(i: integer; var s: string); Преобразует целое значение i к строковому представлению и записывает результат в s
procedure Val(s: string; var value: byte; var err: integer); Преобразует строковое представление s целого числа к числовому значению и записывает его в переменную value. Если преобразование успешно, то err=0, иначе err>0
function Length(s: string): integer; Возвращает длину строки
Тема «Использование цикла for». Вариант программы «Сумма цифр числа» без использования массива
Задание:
Введите число. Найдите сумму цифр. Для решения задачи используйте цикл for и функции работы со строками. Выведите результат на экран.
Program SumNumbers2;
Var
Y : Byte;
Xs : String;
Xr, Summa : Real;
J, N, Err : Integer;
begin
writeln(‘Программа вычисления суммы цифр ‘);
write(‘Введите число X ‘);
readln(Xr);
Str(Xr, Xs); { Преобразовать число в строку }
N := Length(Xs); { Вычислить длину строки }
Summa := 0;
for J := 1 to N do begin
Val(Xs[J], Y, Err); { Преобразовать каждый символ строки к числу }
Summa := Summa + Y;
end;
writeln(‘Сумма цифр ‘, Summa)
end.
Программа вычисления суммы цифр. Вариант решения на PascalABC.NET
- В программе отсутствуют устаревшие в PascalABC.NET конструкции.
- Используются внутриблочные описания переменных: 6 раз
- Используется инициализация при описании: 3 раза
- Для ввода используется функция вида ReadInteger,ReadReal: 1 раз
- Используется расширенное присваивание: 1 раз
- Для вывода использована Print: 2 раза
В программе используются следующие рекомендованные конструкции PascalABC.NET:
Задание:
Введите с клавиатуры целое число. Найдите сумму цифр.
(*
Вариант для PascalABC.NET
*)
begin
var Y, Err : Integer;
Var Xs : String;
Println(‘Программа вычисления суммы цифр’);
var Xr := ReadInteger(‘Введите целое число X ‘);
Str(Xr, Xs); { Преобразовать число в строку }
var N := Length(Xs); { Вычислить длину строки }
var Summa : Integer := 0;
for var J := 1 to N do begin
Val(Xs[J], Y, Err); { Преобразовать каждый символ строки к числу }
Summa += Y;
end;
Println(‘Сумма цифр ‘, Summa)
end.
🔁 Использование циклов. Сумма положительных элементов массива. Циклы for, while, repeat. Шесть примеров решения задачи на языке Паскаль. Варианты для Turbo/Borland/FreePascal и PascalABC.NET
Σ Сумма элементов массива. 🔁 Циклы for, while, repeat. Пять примеров решения задачи на языке Паскаль. В некоторых вариантах используется синтаксис для PascalABC.NET
Σ Сумма случайных чисел. 🔁 Циклы for, while. Три задачи на нахождение суммы случайно сгенерированных элементов. Для каждой задачи приведено два варианта — классический синтаксис (Turbo/Borland Pascal) и PascalABC.NET
Рекламный блок
Информационный блок
Описание задачи
Данная программа должна вывести сумму всех цифр, из которых состоит введенное число.
Решение задачи
- Возьмем введенное число и запишем его в переменную.
- При помощи цикла
while
извлечем каждую цифру из данного числа и запишем их сумму в отдельную переменную. - Выведем полученный результат на экран.
- Конец.
Исходный код
Ниже дан исходный код для вывода суммы всех цифр, из которых состоит данное число. Результаты работы программы также даны ниже.
n = int(input("Введите число:")) tot = 0 while(n > 0): dig = n % 10 tot = tot + dig n = n//10 print("Сумма цифр равна:", tot)
Объяснение работы программы
- Пользователь вводит число, которое записывается в переменную.
- Используем цикл
while
. Цифры извлекаются из числа при помощи оператора деления по модулю, начиная с конца. - Далее записываем эту цифру в отдельную переменную и потом, в процессе работы цикла, прибавляем к ней остальные цифры числа.
- После суммирования цифра «уничтожается» при помощи оператора целочисленного деления.
- Когда число становится равным 0 (все цифры были обработаны и «уничтожены»), цикл завершает свою работу.
- После этого полученная сумма выводится на экран.
Результаты работы программы
Пример 1: Введите число:1892 Сумма цифр равна: 20 Пример 2: Введите число:157 Сумма цифр равна: 13
Сумма и произведение цифр числа
Одной из часто используемых задач для начинающих изучать программирование является нахождение суммы и произведения цифр числа. Число может вводиться с клавиатуры или генерироваться случайно. Задача формулируется так:
Дано число. Найти сумму и произведение его цифр.
Например, сумма цифр числа 253 равна 10-ти, так как 2 + 5 + 3 = 10. Произведение цифр числа 253 равно 30-ти, так как 2 * 5 * 3 = 30.
В данном случае задача осложняется тем, что количество разрядов числа заранее (на момент написания программы) не известно. Это может быть и трехзначное число, как в примере выше, и восьмизначное, и однозначное.
Обычно предполагается, что данная задача должна быть решена арифметическим способом и с использованием цикла. То есть с заданным число должны последовательно выполняться определенные арифметические действия, позволяющие извлечь из него все цифры, затем сложить их и перемножить.
При этом используются операции деления нацело и нахождения остатка. Если число разделить нацело на 10, произойдет «потеря» последней цифры числа. Например, 253 ÷ 10 = 25 (остаток 3). С другой стороны, эта потерянная цифра есть остаток от деления. Получив эту цифру, мы можем добавить ее к сумме цифр и умножить на нее произведение цифр числа.
Пусть n – само число, suma – сумма его цифр, а mult – произведение. Тогда алгоритм нахождения суммы и произведения цифр можно словесно описать так:
- Переменной suma присвоить ноль.
- Переменной mult присвоить единицу. Присваивать 0 нельзя, так как при умножении на ноль результат будет нулевым.
- Пока значение переменной n больше нуля повторять следующие действия:
- Найти остаток от деления значения n на 10, то есть извлечь последнюю цифру числа.
- Добавить извлеченную цифру к сумме и увеличить на эту цифру произведение.
- Избавиться от последнего разряда числа n путем деления нацело на 10.
В языке Python операция нахождения остатка от деления обозначается знаком процента — %
. Деление нацело — двумя слэшами — //
.
Код программы на языке Python
n = int(input()) suma = 0 mult = 1 while n > 0: digit = n % 10 suma = suma + digit mult = mult * digit n = n // 10 print("Сумма:", suma) print("Произведение:", mult)
Пример выполнения:
253 Сумма: 10 Произведение: 30
Изменение значений переменных можно записать в сокращенном виде:
... while n > 0: digit = n % 10 suma += digit mult *= digit n //= 10 ...
Приведенная выше программа подходит только для нахождения суммы и произведения цифр натуральных чисел, то есть целых чисел больше нуля. Если исходное число может быть любым целым, следует учесть обработку отрицательных чисел и нуля.
Если число отрицательное, это не влияет на сумму его цифр. В таком случае достаточно будет использовать встроенную в Python функции abc
, которая возвращает абсолютное значение переданного ей аргумента. Она превратит отрицательное число в положительное, и цикл while
с его условием n > 0
будет работать как и прежде.
Если число равно нулю, то по логике вещей сумма его цифр и их произведение должны иметь нулевые значения. Цикл срабатывать не будет. Поскольку исходное значение mult — это 1, следует добавить проверку на случай, если заданное число — это ноль.
Программа, обрабатывающая все целые числа, может начинаться так:
n = abs(int(input())) suma = 0 mult = 1 if n == 0: mult = 0 ...
Заметим, если в самом числе встречается цифра 0 (например, 503), то произведение всех цифр будет равно нулю. Усложним задачу:
Вводится натуральное число. Найти сумму и произведение цифр, из которых состоит это число. При этом если в числе встречается цифра 0, то ее не надо учитывать при нахождении произведения.
Для решения такой задачи в цикл добавляется проверка извлеченной цифры на ее неравенство нулю. Делать это надо до умножения на нее значения переменной-произведения.
n = int(input()) suma = 0 mult = 1 while n > 0: digit = n % 10 if digit != 0: suma += digit mult *= digit n = n // 10 print("Сумма:", suma) print("Произведение:", mult)
Обратим внимание, что заголовок условного оператора if digit != 0:
в Python можно сократить до просто if digit:
. Потому что 0 — это False
. Все остальные числа считаются истиной.
Приведенный выше математический алгоритм нахождения суммы и произведения цифр числа можно назвать классическим, или универсальным. Подобным способом задачу можно решить на всех императивных языках, независимо от богатства их инструментария. Однако средства языка программирования могут позволить решить задачу другим, зачастую более простым, путем. Например, в Python можно не преобразовывать введенную строку к числу, а извлекать из нее отдельные символы, которые преобразовывать к целочисленному типу int
:
a = input() suma = 0 mult = 1 for digit in a: suma += int(digit) mult *= int(digit) print("Сумма:", suma) print("Произведение:", mult)
Если добавить в код проверку, что извлеченный символ строки действительно является цифрой, то программа станет более универсальной. С ее помощью можно будет считать не только сумму и произведение цифр целых чисел, но и вещественных, а также цифр, извлекаемых из произвольной строки.
n = input() suma = 0 mult = 1 for digit in n: if digit.isdigit(): suma += int(digit) mult *= int(digit) print("Сумма:", suma) print("Произведение:", mult)
Пример выполнения:
это3 чи3с9ло! Сумма: 15 Произведение: 81
Строковый метод isdigit
проверяет, состоит ли строка только из цифр. В нашем случае роль строки играет одиночный, извлеченный на текущей итерации цикла, символ.
Глубокое знание языка Python позволяет решить задачу более экзотическими способами:
import functools n = input() n = [int(digit) for digit in n] suma = sum(n) mult = functools.reduce(lambda x, y: x*y, n) print("Сумма:", suma) print("Произведение:", mult)
Выражение [int(digit) for digit in n]
представляет собой генератор списка. Если была введена строка "234"
, будет получен список чисел: [2, 3, 4]
.
Встроенная функция sum
считает сумму элементов переданного ей аргумента.
Функция reduce
модуля functools
принимает два аргумента — лямбда-выражение и в данном случае список. Здесь в переменной x происходит накопление произведения, а y принимает каждое следующее значение списка.
Больше задач в PDF
Given a number, find the sum of its digits.
Examples :
Input: n = 687
Output: 21Input: n = 12
Output: 3
Follow the below steps to solve the problem:
- Get the number
- Declare a variable to store the sum and set it to 0
- Repeat the next two steps till the number is not 0
- Get the rightmost digit of the number with help of the remainder ‘%’ operator by dividing it by 10 and adding it to the sum.
- Divide the number by 10 with help of ‘/’ operator to remove the rightmost digit.
- Print or return the sum
Below is the implementation of the above approach:
C++
#include <bits/stdc++.h>
using
namespace
std;
class
gfg {
public
:
int
getSum(
int
n)
{
int
sum = 0;
while
(n != 0) {
sum = sum + n % 10;
n = n / 10;
}
return
sum;
}
};
int
main()
{
gfg g;
int
n = 687;
cout << g.getSum(n);
return
0;
}
C
#include <stdio.h>
int
getSum(
int
n)
{
int
sum = 0;
while
(n != 0) {
sum = sum + n % 10;
n = n / 10;
}
return
sum;
}
int
main()
{
int
n = 687;
printf
(
" %d "
, getSum(n));
return
0;
}
Java
import
java.io.*;
class
GFG {
static
int
getSum(
int
n)
{
int
sum =
0
;
while
(n !=
0
) {
sum = sum + n %
10
;
n = n /
10
;
}
return
sum;
}
public
static
void
main(String[] args)
{
int
n =
687
;
System.out.println(getSum(n));
}
}
Python3
def
getSum(n):
sum
=
0
while
(n !
=
0
):
sum
=
sum
+
int
(n
%
10
)
n
=
int
(n
/
10
)
return
sum
if
__name__
=
=
"__main__"
:
n
=
687
print
(getSum(n))
C#
using
System;
class
GFG {
static
int
getSum(
int
n)
{
int
sum = 0;
while
(n != 0) {
sum = sum + n % 10;
n = n / 10;
}
return
sum;
}
public
static
void
Main()
{
int
n = 687;
Console.Write(getSum(n));
}
}
PHP
<?php
function
getsum(
$n
)
{
$sum
= 0;
while
(
$n
!= 0)
{
$sum
=
$sum
+
$n
% 10;
$n
=
$n
/10;
}
return
$sum
;
}
$n
= 687;
$res
= getsum(
$n
);
echo
(
"$res"
);
?>
Javascript
<script>
function
getSum(n)
{
var
sum = 0;
while
(n != 0) {
sum = sum + n % 10;
n = parseInt(n / 10);
}
return
sum;
}
var
n = 687;
document.write(getSum(n));
</script>
Time Complexity: O(log N)
Auxiliary Space: O(1)
How to compute in a single line?
The below function has three lines instead of one line, but it calculates the sum in one line using for loop. It can be made one-line function if we pass the pointer to the sum.
Below is the implementation of the above approach:
C++
#include <bits/stdc++.h>
using
namespace
std;
class
gfg {
public
:
int
getSum(
int
n)
{
int
sum;
for
(sum = 0; n > 0; sum += n % 10, n /= 10)
;
return
sum;
}
};
int
main()
{
gfg g;
int
n = 687;
cout << g.getSum(n);
return
0;
}
C
#include <stdio.h>
int
getSum(
int
n)
{
int
sum;
for
(sum = 0; n > 0; sum += n % 10, n /= 10)
;
return
sum;
}
int
main()
{
int
n = 687;
printf
(
" %d "
, getSum(n));
return
0;
}
Java
import
java.io.*;
class
GFG {
static
int
getSum(
int
n)
{
int
sum;
for
(sum =
0
; n >
0
; sum += n %
10
, n /=
10
)
;
return
sum;
}
public
static
void
main(String[] args)
{
int
n =
687
;
System.out.println(getSum(n));
}
}
Python3
def
getSum(n):
sum
=
0
while
(n >
0
):
sum
+
=
int
(n
%
10
)
n
=
int
(n
/
10
)
return
sum
if
__name__
=
=
"__main__"
:
n
=
687
print
(getSum(n))
C#
using
System;
class
GFG {
static
int
getSum(
int
n)
{
int
sum;
for
(sum = 0; n > 0; sum += n % 10, n /= 10)
;
return
sum;
}
public
static
void
Main()
{
int
n = 687;
Console.Write(getSum(n));
}
}
PHP
<?php
function
getsum(
$n
)
{
for
(
$sum
= 0;
$n
> 0;
$sum
+=
$n
% 10,
$n
/= 10);
return
$sum
;
}
$n
= 687;
echo
(getsum(
$n
));
?>
Javascript
<script>
function
getSum(n)
{
let sum;
for
(sum = 0; n > 0;
sum += n % 10,
n = parseInt(n / 10))
;
return
sum;
}
let n = 687;
document.write(getSum(n));
</script>
Time Complexity: O(log N)
Auxiliary Space: O(1)
Sum of the digits of a given number using recursion:
Follow the below steps to solve the problem:
- Get the number
- Get the remainder and pass the next remaining digits
- Get the rightmost digit of the number with help of the remainder ‘%’ operator by dividing it by 10 and adding it to the sum.
- Divide the number by 10 with help of the ‘/’ operator to remove the rightmost digit.
- Check the base case with n = 0
- Print or return the sum
Below is the implementation of the above approach:
C++
#include <iostream>
using
namespace
std;
class
gfg {
public
:
int
sumDigits(
int
no)
{
if
(no == 0) {
return
0;
}
return
(no % 10) + sumDigits(no / 10);
}
};
int
main(
void
)
{
gfg g;
cout << g.sumDigits(687);
return
0;
}
C
#include <stdio.h>
int
sumDigits(
int
no)
{
if
(no == 0) {
return
0;
}
return
(no % 10) + sumDigits(no / 10);
}
int
main()
{
printf
(
"%d"
, sumDigits(687));
return
0;
}
Java
import
java.io.*;
class
GFG {
static
int
sumDigits(
int
no)
{
if
(no ==
0
) {
return
0
;
}
return
(no %
10
) + sumDigits(no /
10
);
}
public
static
void
main(String[] args)
{
System.out.println(sumDigits(
687
));
}
}
Python3
def
sumDigits(no):
return
0
if
no
=
=
0
else
int
(no
%
10
)
+
sumDigits(
int
(no
/
10
))
if
__name__
=
=
"__main__"
:
print
(sumDigits(
687
))
C#
using
System;
class
GFG {
static
int
sumDigits(
int
no)
{
return
no == 0 ? 0 : no % 10 + sumDigits(no / 10);
}
public
static
void
Main()
{
Console.Write(sumDigits(687));
}
}
PHP
<?php
function
sumDigits(
$no
)
{
return
$no
== 0 ? 0 :
$no
% 10 +
sumDigits(
$no
/ 10) ;
}
echo
sumDigits(687);
?>
Javascript
<script>
function
sumDigits(no)
{
if
(no == 0){
return
0 ;
}
return
(no % 10) + sumDigits(parseInt(no/10)) ;
}
document.write(sumDigits(687));
</script>
Time Complexity: O(log N)
Auxiliary Space: O(log N)
Sum of the digits of a given number with input as string:
When the number of digits of that number exceeds 1019 , we can’t take that number as an integer since the range of long long int doesn’t satisfy the given number. So take input as a string, run a loop from start to the length of the string and increase the sum with that character(in this case it is numeric)
Follow the below steps to solve the problem:
- Declare a variable sum equal to zero
- Run a loop from zero to the length of the input string
- Add the value of each character into the sum, by converting the character into it’s integer value
- Return sum
Below is the implementation of the above approach:
C++14
#include <bits/stdc++.h>
using
namespace
std;
int
getSum(string str)
{
int
sum = 0;
for
(
int
i = 0; i < str.length(); i++) {
sum = sum + str[i] - 48;
}
return
sum;
}
int
main()
{
string st =
"123456789123456789123422"
;
cout << getSum(st);
return
0;
}
Java
import
java.io.*;
class
GFG {
static
int
getSum(String str)
{
int
sum =
0
;
for
(
int
i =
0
; i < str.length(); i++) {
sum = sum + str.charAt(i) -
48
;
}
return
sum;
}
public
static
void
main(String[] args)
{
String st =
"123456789123456789123422"
;
System.out.print(getSum(st));
}
}
Python3
def
getSum(n):
sum
=
0
for
i
in
n:
sum
=
sum
+
int
(i)
return
sum
if
__name__
=
=
"__main__"
:
n
=
"123456789123456789123422"
print
(getSum(n))
C#
using
System;
public
class
GFG {
static
int
getSum(String str)
{
int
sum = 0;
for
(
int
i = 0; i < str.Length; i++) {
sum = sum + str[i] - 48;
}
return
sum;
}
static
public
void
Main()
{
String st =
"123456789123456789123422"
;
Console.Write(getSum(st));
}
}
PHP
<?php
function
getsum(
$str
)
{
$sum
= 0;
for
(
$i
= 0;
$i
<
strlen
(
$str
);
$i
++) {
$sum
=
$sum
+ (int)
$str
[
$i
];
}
return
$sum
;
}
$str
=
"123456789123456789123422"
;
echo
(getsum(
$str
));
?>
Javascript
<script>
function
getSum(str)
{
let sum = 0;
for
(let i = 0; i < str.length; i++)
{
sum = sum + parseInt(str[i]);
}
return
sum;
}
let st =
"123456789123456789123422"
;
document.write(getSum(st));
</script>
Time Complexity: O(N)
Auxiliary Space: O(1)
Sum of the digits of a given number using tail recursion:
Follow the below steps to solve the problem:
- Add another variable “Val” to the function and initialize it to ( Val = 0 )
- On every call to the function add the mod value (n%10) to the variable as “(n%10)+val” which is the last digit in n. Along with passing the variable n as n/10.
- So on the First call, it will have the last digit. As we are passing n/10 as n, It follows until n is reduced to a single digit.
- n<10 is the base case so When n < 10, then add the n to the variable as it is the last digit and return the val which will have the sum of digits
Below is the implementation of the above approach:
C++
#include <bits/stdc++.h>
using
namespace
std;
int
sum_of_digit(
int
n,
int
val)
{
if
(n < 10) {
val = val + n;
return
val;
}
return
sum_of_digit(n / 10, (n % 10) + val);
}
int
main()
{
int
num = 12345;
int
result = sum_of_digit(num, 0);
cout <<
"Sum of digits is "
<< result;
return
0;
}
C
#include <stdio.h>
int
sum_of_digit(
int
n,
int
val)
{
if
(n < 10) {
val = val + n;
return
val;
}
return
sum_of_digit(n / 10, (n % 10) + val);
}
int
main()
{
int
num = 12345;
int
result = sum_of_digit(num, 0);
printf
(
"Sum of digits is %d"
, result);
return
0;
}
Java
import
java.io.*;
import
java.lang.*;
import
java.util.*;
class
sum_of_digits {
static
int
sum_of_digit(
int
n,
int
val)
{
if
(n <
10
) {
val = val + n;
return
val;
}
return
sum_of_digit(n /
10
, (n %
10
) + val);
}
public
static
void
main(String args[])
{
int
num =
12345
;
int
result = sum_of_digit(num,
0
);
System.out.println(
"Sum of digits is "
+ result);
}
}
Python3
def
sum_of_digit(n, val):
if
(n <
10
):
val
=
val
+
n
return
val
return
sum_of_digit(n
/
/
10
, (n
%
10
)
+
val)
if
__name__
=
=
"__main__"
:
num
=
12345
result
=
sum_of_digit(num,
0
)
print
(
"Sum of digits is"
, result)
C#
using
System;
class
GFG {
static
int
sum_of_digit(
int
n,
int
val)
{
if
(n < 10) {
val = val + n;
return
val;
}
return
sum_of_digit(n / 10, (n % 10) + val);
}
public
static
void
Main()
{
int
num = 12345;
int
result = sum_of_digit(num, 0);
Console.Write(
"Sum of digits is "
+ result);
}
}
Javascript
<script>
function
sum_of_digit(n, val)
{
if
(n < 10)
{
val = val + n;
return
val;
}
return
sum_of_digit(parseInt(n / 10),
(n % 10) + val);
}
let num = 12345;
let result = sum_of_digit(num, 0);
document.write(
"Sum of digits is "
+ result);
</script>
Output
Sum of digits is 15
Time Complexity: O(log N)
Auxiliary Space: O(log N)
Please write comments if you find the above codes/algorithms incorrect, or find better ways to solve the same problem.
Last Updated :
05 Dec, 2022
Like Article
Save Article
Перейти к содержанию
Сумма и произведение цифр числа
Просмотров 8.4к. Обновлено 29 октября 2021
Если трехзначное число нацело разделить на 100, то получим число сотен, т.е. первую цифру этого числа.
Если найти остаток от деления на 10 любого целого числа, то этот остаток покажет число единиц в этом числе. Таким образом извлекается последняя цифра числа.
Чтобы извлечь среднюю цифру трехзначного числа (показывающую количество десятков), можно выполнить два действия:
- Разделить число нацело на 10. Тем самым избавиться от последней цифры трехзначного числа, превратив его в двузначное.
- Найти остаток от деления полученного двузначного числа на 10. Этот остаток и будет средняя цифра первоначального трехзначного числа.
Извлекая вышеописанным способом цифры числа их надо присвоить переменным. Т.к. цифр три, то и переменных будет три. После этого выполнить сложение и умножение значений переменных.
Pascal
произведение цифр числа паскаль и сумма цифр числа паскаль
var
n: integer;
a,b,c: byte;
begin
readln(n);
a := n div 100;
b := n div 10 mod 10;
c := n mod 10;
writeln('Сумма: ',a+b+c);
writeln('Произведение: ',a*b*c);
end.
Язык Си
произведение цифр числа си и сумма цифр числа си
#includemain() {
int n,a,b,c;
scanf("%d", &n);
a = n / 100;
b = n / 10 % 10;
c = n % 10;
printf("Сумма: %dn", a+b+c);
printf("Произведение: %dn", a*b*c);
}
349
Сумма: 16
Произведение: 108
Целочисленное деление выполняется в том случае, если оба операнда целые. Т.е. у целочисленного деления нет специального знака, а выбор между ним и обычным делением зависит от операндов. Если хотя бы один из операндов вещественное число, то и деление будет обычным.
Python
произведение цифр числа Python и сумма цифр числа Python
n = input("Введите трехзначное число: ")
n = int(n)d1 = n % 10
d2 = n % 100 // 10
d3 = n // 100print("Сумма цифр числа:", d1 + d2 + d3)
print("Произведение цифр числа:", d1 * d2 * d3)
Введите трехзначное число: 742
Сумма цифр числа: 13
Произведение цифр числа: 56
КуМир
алг сумма цифр
нач
ввод n
a := div(n,100)
b := mod(div(n,10),10)
c := mod(n,10)
вывод "Сумма: ", a+b+c, нс
вывод "Произведение: ", a*b*c, нс
кон
Basic-256
input na = n 100
b = n 10 % 10
c = n % 10print a+b+c
print a*b*c
Обратите внимание на знак целочисленного деления. Это обратный слэш (), в то время как обычное деление обозначается обычным слэшем (/).