С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/26: Рейтинг темы: голосов - 26, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 18.02.2018
Сообщений: 1
1

Задача на бинарный Поиск

18.02.2018, 00:15. Показов 4766. Ответов 2

Author24 — интернет-сервис помощи студентам
Задано число k. Каждый студенческий совет должен состоять из k студентов. Важное правило — каждый совет состоит из студентов из разных групп. То есть никакие два студента из одной группы не могут оказаться в одном совете.

Конечно, каждый студент должен входить не более чем в один совет (возможно, что некоторые студенты не входят ни в один).

Задан массив a[1..n], где a[i] — количество студентов в i-ой группе. Какое максимальное число советов может быть образовано?


Входные данные
В первой строке задано k (2 ≤ k ≤ 20). Далее задано n (k ≤ n ≤ 50). Затем заданы элементы a[1], a[2],..., a[n] (1 ≤ a[i] ≤ 1000000000). Все числа разделяются пробелами и/или переводами строк.


Выходные данные
Выведите искомое значение.


Пример(ы)
input
4 5
4 4 4 4 4
output
5

input
5 6
1 2 3
4 5 6
output
3
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
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
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <algorithm>
#include <vector>
#include <utility>
#include <string>
#include <set>
#include <map>
#include <stack>
#include <fstream>
#include <queue>
#include <cstring>
 
#define forn(i,n) for (ll i = 0; i < ll(n); i++)
#define pb push_back
#define sz(v) v.size()
#define all(v) v.begin(),v.end()
#define x first
#define y second
#define mp make_pair
 
typedef long long ll;
 
const long long INF64 = 1e18;
const ll INF = 1e9;
 
 
using namespace std;
 
ll k, n;
bool kek(ll d, vector<ll> &a) {
    ll summ = 0;
    forn(i, n) {
        if (a[i] <= d) summ += a[i];
        else summ += d;
    }   
    return summ >= k * 1ll * d;
}
 
signed main() {
 
 
    cin >> k >> n;
    vector<ll> a(n);
    forn(i, n) cin >> a[i];
    if (k > n) {
        cout << 0;
        return 0;
    }
    ll l = 1, r = INF64;
    while (l < r - 1) {
        ll mid = (l + r) / 2;
        if (kek(mid, a))
            l = mid;
        else r = mid;
    }
    for (ll i = r; i >= l; --i) {
        if (kek(i, a)) {
            cout << i;
            return 0;
        }
    }
    cout << 0;
    return 0;
}
Не проходит 1/4 тестов в тестере (Wrong Answer), примеров тестов нет. HElp
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.02.2018, 00:15
Ответы с готовыми решениями:

Задача про провода: бинарный поиск
Дано N отрезков провода длиной L1, L2, ..., LN сантиметров. Требуется с помощью разрезания получить...

Поиск числа в двумерном массиве (бинарный поиск)
Произвожу поиск элемента в массиве двумя способами: линейным(последовательным) поиском и...

Бинарный поиск
Что переделать в программе, чтобы она находила первый элемент больше или равный заданному? ...

Бинарный поиск
Реализация на С++: int Search_Binary (int arr, int left, int right, int key) { int midd = 0; ...

2
2 / 1 / 1
Регистрация: 28.12.2022
Сообщений: 6
15.01.2023, 10:50 2
брат, у тебя переполнение, так как если К >= 10 то long long не будет это поддерживать INF64 на 1e16
0
4264 / 3323 / 925
Регистрация: 25.03.2012
Сообщений: 12,520
Записей в блоге: 1
16.01.2023, 05:37 3
inst_podumaru, вот какой смысл твоего коммента? Ты спецом искал тему из прошлого столетия чтоб отписаться в ней?
0
16.01.2023, 05:37
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.01.2023, 05:37
Помогаю со студенческими работами здесь

Бинарный поиск
Прочитал статью на хабре, о том, что только 10 проц программистов смогут реализовать бин поиск....

Бинарный поиск
Никак не могу понять почему у меня не проходит тесты данный код. Задача выглядит так: Входные...

Бинарный поиск
Заполнить массив случайными числами и отсортировать его. Ввести число X. Используя двоичный поиск,...

Бинарный поиск
Писал алгоритм бинарного поиска по массиву строк. В результате, почему-то, периодически функция не...

Бинарный поиск
Реализовать алгоритм бинарного поиска количества нулевых элементов двумерного динамического...

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru