Форум программистов, компьютерный форум, киберфорум
Pascal ABC
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
5 / 1 / 0
Регистрация: 06.05.2017
Сообщений: 32

Найти в заданном виде сумму заданных чисел, не вычисляя самих чисел.

20.06.2017, 14:25. Показов 1495. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Своими цифрами в массивах K(M) и L(N) заданы 2 целых числа в p-ичной системе счисления(p<=10)Найти в таком же виде их сумму, не вычисляя самих чисел.
Помогите пожалуйста,буду очень благодарен
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.06.2017, 14:25
Ответы с готовыми решениями:

Для заданных 10 чисел найти: сумму и произведение четных чисел
Для заданных 10 чисел найти: сумму и произведение четных чисел

Найти сумму целых чисел в заданном интервале
Нужно реализовать задачи на Паскаль. Задачи прикрепила. Помогите пожалуйста, нужно сделать кроме 3.

Составить процедуру, которая для заданных чисел m,n определяет сумму десятичных разрядов этих чисел
Составить процедуру, которая для заданных чисел m,n определяет сумму десятичных разрядов этих чисел(например для 123 и 456 сумма =21,...

2
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
20.06.2017, 17:27
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
type mas=array[1..1001] of byte;
//ввод массива
procedure vvod(var a:mas;var n:integer;p:byte;c:char);
var i:integer;
begin
repeat
write('Введите размер массива от 1 до 500 n=');
readln(n);
until(n>0)and(n<=500);
writeln('Массив ',c);
for i:=1 to n do//заполним массив
 begin
  if i=1 then a[i]:=1+random(p-1) //первая не 0
  else a[i]:=random(p);
  write(a[i]);
 end;
writeln;
end;
//переворот массива
procedure revers(var a:mas;n:integer);
var i,x:integer;
begin
for i:=1 to n div 2 do
 begin
  x:=a[i];
  a[i]:=a[n-i+1];
  a[n-i+1]:=x;
 end;
end;
var k,l,a:mas;
    m,n,i,q:integer;
    p,os,pr:byte;
begin
randomize;
repeat
write('Введите систему счисления от 2 до 10 p=');
readln(p);
until p in [2..10];
vvod(k,m,p,'K');
vvod(l,n,p,'L');
revers(k,m);
revers(l,n);
if m<n then
 begin
  for i:=m+1 to n do
  k[i]:=0;
  q:=n;
 end
else if n<m then
 begin
  for i:=n+1 to m do
  l[i]:=0;
  q:=m;
 end;
pr:=0;
for i:=1 to q do
 begin
  a[i]:=(pr+k[i]+l[i])mod p;
  pr:=(pr+k[i]+l[i])div p;
 end;
if pr>0 then
 begin
  q:=q+1;
  a[q]:=pr;
 end;
revers(a,q);
writeln('Сумма:');
for i:=1 to q do
write(a[i]);
end.
0
3410 / 1829 / 489
Регистрация: 28.02.2015
Сообщений: 3,696
20.06.2017, 18:38
Лучший ответ Сообщение было отмечено hawxalexrus как решение

Решение

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
const
  m=8;
  n=9;
var
  a:string;
  k:array[0..m]of integer;
  l:array[0..n]of integer;
  c,i,p:integer;
function Num2Str(a:integer):string;
  var
    b:string;
  begin
    b:='';
    if a=0 then b:='0';
    while a>0 do
      begin
        b:=chr((a mod 10)+ord('0'))+b;
        a:=a div 10;
      end;
    Num2Str:=b;
  end;
begin
  {create}
  randomize;
  p:=random(10)+10;
  a:='';
  for i:=0 to m do
    begin
      k[i]:=random(p);
      if k[i]>0 then
        if k[i]<10 then a:=chr(k[i]+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a
          else a:=chr(k[i]+ord('A')-10)+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
    end;
  delete(a,length(a),1);
  writeln('number K :',a);
  a:='';
  for i:=0 to n do
    begin
      l[i]:=random(p);
      if l[i]>0 then
        if l[i]<10 then a:=chr(l[i]+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a
          else a:=chr(l[i]+ord('A')-10)+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
    end;
  delete(a,length(a),1);
  writeln('number L :',a);
  a:='';
  i:=0;
  c:=0;
  while(c>0)or(i<=n)or(i<=m)do
    begin
      if i<=m then c:=c+k[i];
      if i<=n then c:=c+l[i];
      if (c mod p)>0 then
        if(c mod p)<10 then a:=chr((c mod p)+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a
          else a:=chr((c mod p)+ord('A')-10)+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
      inc(i);
      c:=c div p;
    end;
  delete(a,length(a),1);
  writeln('summa K+L:',a);
  writeln;
end.
Добавлено через 5 минут

Блин, я сделал для р больше равно 10.

Переделал.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
const
  m=8;
  n=9;
var
  a:string;
  k:array[0..m]of integer;
  l:array[0..n]of integer;
  c,i,p:integer;
function Num2Str(a:integer):string;
  var
    b:string;
  begin
    b:='';
    if a=0 then b:='0';
    while a>0 do
      begin
        b:=chr((a mod 10)+ord('0'))+b;
        a:=a div 10;
      end;
    Num2Str:=b;
  end;
begin
  {create}
  randomize;
  p:=random(8)+2;
  a:='';
  for i:=0 to m do
    begin
      k[i]:=random(p);
      if k[i]>0 then a:=chr(k[i]+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
    end;
  delete(a,length(a),1);
  writeln('number K :',a);
  a:='';
  for i:=0 to n do
    begin
      l[i]:=random(p);
      if l[i]>0 then a:=chr(l[i]+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
    end;
  delete(a,length(a),1);
  writeln('number L :',a);
  a:='';
  i:=0;
  c:=0;
  while(c>0)or(i<=n)or(i<=m)do
    begin
      if i<=m then c:=c+k[i];
      if i<=n then c:=c+l[i];
      if (c mod p)>0 then a:=chr((c mod p)+ord('0'))+'*'+Num2Str(p)+'^'+Num2Str(i)+'+'+a;
      inc(i);
      c:=c div p;
    end;
  delete(a,length(a),1);
  writeln('summa K+L:',a);
  writeln;
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.06.2017, 18:38
Помогаю со студенческими работами здесь

С клавиатуры вводится N целых чисел a1, a2,….,aN. Найти сумму этих чисел. Найти номер первого четного числа последовательности чисел.
Решить задачу 3 способами: 1. Используя метки и оператор goto (не используя никакой цикл) 2. Используя цикл (repeat или while) 3....

Найти сумму нечетных чисел файла в заданном диапазоне
1.​Программно создать текстовый файл из N целых чисел. N: 20-80, числа создать с помощью датчика случайных чисел в диапазоне , k- номер...

Найти все натуральные числа в заданном интервале, представимые в виде суммы квадратов трех натуральных чисел
Найти все натуральные числа от 1 до N, представимые в виде суммы квадратов трех натуральных чисел.

Найти сумму четных чисел, которые находятся в заданном интервале
Найти сумму четных чисел, которые находятся в интервале (24,70) используя оператор цикла с постусловием &quot;REPEAT&quot;.

Найти сумму кубов всех целых чисел в заданном диапазоне
Найти:1) сумму кубов всех целых чисел от 1 до п (значение п вводится с клавиатуры; 1 &lt; п &lt; 100); 2) сумму кубов всех целых чисел от а...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru