Форум программистов, компьютерный форум CyberForum.ru

Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN - C++

Восстановить пароль Регистрация
 
Slava0309
1 / 1 / 0
Регистрация: 20.12.2012
Сообщений: 19
09.04.2013, 20:26     Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN #1
Задача 32 «Взвешивания»

Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN. Числа G,N,Mi -целые ;ответ выдать в форме YES - если взвесить можно, NO - если нельзя.

Ввод: 1-я строка G N - вес груза и количество гирь, 2-я строка через пробелы массы гирь Мi.

Вывод: ответ YES или NO .

Пример :

Ввод: Вывод:

150 4 YES

100 30 300 20
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.04.2013, 20:26     Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN
Посмотрите здесь:

C++ написать программу, при помощи которой можно проверять синтаксические ошибки слов текста, хранящегося в файле
C++ Граф задан мартрицей весов.Нужно определить ребра с максимальным весом и удалить их
Среди 13 монет есть одна отличающаяся по весу, за 3 взвешивания на чашечных весах найти ее C++
C++ Напечатать таблицу соответствия между весом в фунтах и весом в килограммах
C++ Что можно сделать при помощи Shell Extensions?
Вложенные циклы: Сколькими способами гирями данного набора можно составить вес в v грамм C++
Как можно считывать из строки (std::string или char*) данные при помощи cin C++
Определить координаты элемента матрицы с наименьшим весом C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ternsip
 Аватар для Ternsip
660 / 188 / 6
Регистрация: 10.05.2012
Сообщений: 595
10.04.2013, 14:34     Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN #2
Slava0309, может, можно решить жадно, но мне напомнило уже известную задачу о рюкзаке. Вот код
C++
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
#include <iostream>
#include <cmath>
#include <algorithm>
#include <vector>
#include <limits>
#include <queue>
#include <string>
#include <set>
#include <stack>
#include <tuple>
 
using namespace std;
 
int main(){         
    freopen("input.txt", "rt", stdin);
    freopen("output.txt", "wt", stdout);
     vector <bool> ranec(1001, false);
    ranec[0] = 1;
    int n, q;
    cin >> q >> n;
    for (int i = 0; i < n; i++){
        int w;
        cin >> w;
        for (int j = q - w; j >= 0; j--){
            if (ranec[j]){
                ranec[j + w] = true;
            }
        }
    }
    cout << (ranec[q]?"YES":"NO");
    return 0;
}
Yandex
Объявления
10.04.2013, 14:34     Определить, можно ли на чашечных весах взвесить груз весом G при помощи набора из N гирь масами М1,М2,...МN
Ответ Создать тему
Опции темы

Текущее время: 16:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru