Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/25: Рейтинг темы: голосов - 25, средняя оценка - 4.64
1 / 1 / 0
Регистрация: 22.01.2014
Сообщений: 45
1

Определить, можно ли привести весы в состояние равновесия

23.06.2015, 19:31. Показов 4881. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Даны двухчашечные весы и набор гирек. На левую чашу весов положили взвешиваемый предмет весом K граммов. Можно ли привести весы в состояние равновесия, и если можно, то определите для каждой чаши весов, какие гирьки на нее для этого нужно положить. Имеющиеся гирьки разрешается класть на любую из чаш весов (каждая гирька имеется только в одном экземпляре, некоторые гирьки можно не использовать).
Входные данные

Вводится сначала K — вес предмета, который положили на левую чашу (1≤K≤50). Далее записано общее количество гирек N (1≤N≤10). Далее записано N различных натуральных чисел, не превышающих 50, — веса гирек.
Выходные данные

В первой строке выведите веса гирек, которые нужно поместить на левую чашу весов, во второй строке — гирьки, которые нужно поместить на правую чашу. Если на какую-то чашу ни одной гирьки помещать не нужно — выведите в этой строке число 0. Если с помощью данных гирек привести весы в равновесие нельзя, выведите одно число –1. Если вариантов несколько, выведите любой из них.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.06.2015, 19:31
Ответы с готовыми решениями:

Привести код в рабочее состояние
Здравствуйте! Есть задание в котором нужно ввести информацию о такси (номер, стоимость, вид...

Привести код в читаемое состояние
Нашёл код игры, которую требуется для лабы, попробовал сдать, но работу не приняли, сказали...

Привести код в рабочее состояние
Есть две задачи, на обе есть два исходных кода, оба в не рабочем состоянии: Код первой...

Как привести ОС в нормальное состояние?
Всем привет! Года 2 уже не переустанавливал винду. Накопилось много мусора, система стала...

3
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
23.06.2015, 20:41 2
Взвешивание самородков с использованием минимального числа гирь.
из той же оперы.
0
Эксперт Pascal/Delphi
2386 / 1298 / 1492
Регистрация: 29.08.2014
Сообщений: 4,661
23.06.2015, 21:49 3
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

в лоб(прямой перебор вариантов) так:
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
var
  p:array[1..10] of integer;
  i1,i2,i3,i4,i5,i6,i7,i8,i9,i10,j1,j2,j3,j4,j5,j6,j7,j8,j9,j10,k,n:integer;
begin
  readln(k);
  readln(n);
  for n:=1 to n do  read(p[n]);
  for i1:=0 to 1 do
  for i2:=0 to 1 do
  for i3:=0 to 1 do
  for i4:=0 to 1 do
  for i5:=0 to 1 do
  for i6:=0 to 1 do
  for i7:=0 to 1 do
  for i8:=0 to 1 do
  for i9:=0 to 1 do
  for i10:=0 to 1 do
  for j1:=0 to 1 do
  for j2:=0 to 1 do
  for j3:=0 to 1 do
  for j4:=0 to 1 do
  for j5:=0 to 1 do
  for j6:=0 to 1 do
  for j7:=0 to 1 do
  for j8:=0 to 1 do
  for j9:=0 to 1 do
  for j10:=0 to 1 do
   if k+i1*p[1]+i2*p[2]+i3*p[3]+i4*p[4]+i5*p[5]+i6*p[6]+i7*p[7]+i8*p[8]+i9*p[9]+i10*p[10]=
      j1*p[1]+j2*p[2]+j3*p[3]+j4*p[4]+i5*p[5]+j6*p[6]+j7*p[7]+j8*p[8]+j9*p[9]+j10*p[10]
   then begin
      if i1*p[1]>0 then write(p[1],' ');
      if i2*p[2]>0 then write(p[2],' ');
      if i3*p[3]>0 then write(p[3],' ');
      if i4*p[4]>0 then write(p[4],' ');
      if i5*p[5]>0 then write(p[5],' ');
      if i6*p[6]>0 then write(p[6],' ');
      if i7*p[7]>0 then write(p[7],' ');
      if i8*p[8]>0 then write(p[8],' ');
      if i9*p[9]>0 then write(p[9],' ');
      if i10*p[10]>0 then write(p[10],' ');
      if i1*p[1]+i2*p[2]+i3*p[3]+i4*p[4]+i5*p[5]+i6*p[6]+i7*p[7]+i8*p[8]+i9*p[9]+i10*p[10]=0 then write('0');
      writeln;
      if j1*p[1]>0 then write(p[1],' ');
      if j2*p[2]>0 then write(p[2],' ');
      if j3*p[3]>0 then write(p[3],' ');
      if j4*p[4]>0 then write(p[4],' ');
      if j5*p[5]>0 then write(p[5],' ');
      if j6*p[6]>0 then write(p[6],' ');
      if j7*p[7]>0 then write(p[7],' ');
      if j8*p[8]>0 then write(p[8],' ');
      if j9*p[9]>0 then write(p[9],' ');
      if j10*p[10]>0 then write(p[10],' ');
      if j1*p[1]+j2*p[2]+j3*p[3]+j4*p[4]+i5*p[5]+j6*p[6]+j7*p[7]+j8*p[8]+j9*p[9]+j10*p[10]=0 then write('0');
      exit;
   end;
   writeln('-1');
 end.
0
Модератор
10076 / 5417 / 3356
Регистрация: 17.08.2012
Сообщений: 16,583
24.06.2015, 15:32 4
Перебором, с проверкой ввода, выводится первый найденный вариант:
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
71
72
const maxweight = 50;
      maxquantity = 10;
 
var i, j, k, n, sum, carry: integer;
    weights: array [1..maxquantity] of integer;
    scales: array [1..maxquantity] of integer;
    overflow, correct: boolean;
 
procedure prnscales(bowl: integer);
var notfound: boolean;
    i: integer;
begin
  notfound := true;
  for i := 1 to n do
    if scales[i] = bowl
      then begin
        write(weights[i]:3);
        notfound := false
      end;
  if notfound then write(0:3);
  writeln
end;
 
begin
  repeat
    write('K in [1..', maxweight, '];  K = ');
    readln(k)
  until k in [1..maxweight];
  repeat
    write('N in [1..', maxquantity, '];  N = ');
    readln(n)
  until n in [1..maxquantity];
  writeln('Enter the weight of weights (in [1..', maxweight, ']):');
  for i := 1 to n do
    repeat
      write('Weight ', i, ': ');
      readln(weights[i]);
      for j := 1 to i - 1 do
        if weights[i] = weights[j]
          then begin
            writeln('Such weight already is in a set, reenter');
            weights[i] := 0
          end;
    until weights[i] in [1..maxweight];
  for i := 1 to n do scales[i] := 1;
  repeat
    inc(scales[1]);
    carry := 0;
    for i := 1 to n do
      begin
        scales[i] := scales[i] + carry;
        if scales[i] > 1
          then begin
            carry := 1;
            scales[i] := -1
          end
          else break
      end;
    sum := 0;
    for i := 1 to n do sum := sum + scales[i] * weights[i];
    correct := sum = k;
    overflow := true;
    for i := 1 to n do overflow := overflow and (scales[i] = 1)
  until correct or overflow;
  if correct
    then begin
      prnscales(-1);
      prnscales(1)
    end
    else write(-1:3);
  readln
end.
На всякий случай:
Специальный (идиотский) вариант для скармливания "олимпийскому"/"обучающему" сайту
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
var i, k, n, s, c: integer;
    w: array [1..10] of integer;
    v: array [1..10] of integer;
    f, t: boolean;
 
procedure p(b: integer);
var n: boolean;
    i: integer;
begin
  n := true;
  for i := 1 to n do
    if v[i] = b
      then begin
        write(w[i]:3);
        n := false
      end;
  if n then write(0);
  writeln
end;
 
begin
  readln(k)
  readln(n)
  for i := 1 to n do read(w[i]);
  for i := 1 to n do v[i] := 1;
  repeat
    inc(v[1]);
    c := 0;
    for i := 1 to n do
      begin
        v[i] := v[i] + c;
        if v[i] > 1
          then begin
            c := 1;
            v[i] := -1
          end
          else break
      end;
    s := 0;
    for i := 1 to n do s := s + v[i] * w[i];
    t := s = k;
    f := true;
    for i := 1 to n do f := f and (v[i] = 1)
  until t or f;
  if t
    then begin
      p(-1);
      p(1)
    end
    else write(-1)
end.
1
24.06.2015, 15:32
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.06.2015, 15:32
Помогаю со студенческими работами здесь

Как привести StringGrid в исходное состояние?
как привести StringGrid в исходное состояние? к примеру в StingGrid было внесено что-либо. но...

как привести компьютер в рабочее состояние после ***stop: OX0000007B?
Помогите пожалуйста, привести комп-р в рабочее состояние!!!!......Дело в том, что после послед-го...

Реализовать и привести в рабочее состояние программу по представленному интерфейсу и коду
Помогите реализовать и привести в рабочее состояние программу по представленному интерфейсу и коду....

Можно ли при гибернации сохранить состояние нескольких приложений, но при этом не сохранять состояние системы?
можно сохранить состояние нескольких приложений, но при этом не сохранять состояние системы? убил...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Преобразование полей (элементов управления содержимым) в обычный текст
РоΜа 23.01.2025
Возникла необходимость преобразовать поля в текст (те, что на вкладке разработчик добавляются) . Помучившись родил следующее: Sub ПоляВТекст() Преобразует все поля в текст (даты, текст,. . .
Как проверить существование директории в скрипте Bash
bt_guru 23.01.2025
При разработке скриптов Bash одной из ключевых задач является корректная работа с файловой системой, где особое место занимает проверка существования директорий. Эта операция становится критически. . .
Как работают срезы (slice) в Python
bytestream 23.01.2025
Python предоставляет разработчикам мощный и гибкий инструмент для работы с последовательностями данных - срезы (slices). Эта функциональность позволяет извлекать, модифицировать и управлять. . .
Как удалить подмодуль (submodule) в Git
bytestream 23.01.2025
При работе с крупными проектами в системе контроля версий Git разработчики часто сталкиваются с необходимостью управления зависимостями и внешними компонентами. Подмодули (submodules) представляют. . .
В чем разница между @staticmethod и @classmethod в Python. Декораторы методов
bytestream 23.01.2025
В Python декораторы методов представляют собой мощный инструмент, позволяющий модифицировать поведение функций и методов без изменения их исходного кода. Эта возможность является одной из. . .
Как преобразовать InputStream в String в Java
bytestream 23.01.2025
В мире Java-разработки работа с потоками данных является одной из ключевых операций при создании современных приложений. InputStream, как фундаментальный класс для обработки входных потоков данных,. . .
Как обновить форк (ответвление) репозитория в Git
bytestream 23.01.2025
Одним из наиболее мощных инструментов Git для организации совместной работы является механизм форкинга репозиториев, который позволяет создавать независимые копии проектов для дальнейшей разработки. . . .
Как работает async/await в C#. Асинхронное программировани­е в .NET
bytestream 23.01.2025
Введение в асинхронное программирование Асинхронное программирование представляет собой важнейшую концепцию современной разработки программного обеспечения, особенно в контексте создания. . .
КуМир: полное руководство
bytestream 23.01.2025
Введение в КуМир: история создания и назначение КуМир (Комплект Учебных МИров) представляет собой образовательную среду программирования, которая была создана для обучения основам алгоритмизации и. . .
Что такое OLAP. Где и как использовать многомерный анализ данных
bytestream 23.01.2025
Введение в OLAP-технологии В современном мире бизнес-аналитика и обработка больших массивов данных играют ключевую роль в принятии стратегических решений. Организации накапливают огромные объемы. . .
MongoDB: что это, для чего нужна и как использовать
bytestream 23.01.2025
Введение в MongoDB: современная документоориентированная СУБД В современном мире разработки программного обеспечения выбор правильной системы управления базами данных является критически важным. . .
Как использовать закрытый ключ шифрования в Git. Шифрование в Git
bytestream 23.01.2025
Установка и настройка закрытых ключей в Git предоставляет дополнительный уровень безопасности для работы с репозиториями. Для начала необходимо создать пару ключей, обычно это осуществляется с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru