Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 5.00/15: Рейтинг темы: голосов - 15, средняя оценка - 5.00
34 / 25 / 8
Регистрация: 16.11.2019
Сообщений: 179

Клиппи и Мерлин

25.03.2020, 13:03. Показов 3313. Ответов 31
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Клиппи и Мерлин решили грабить банк, который представляет собой N расположенных в ряд банковских ячеек, пронумерованных последовательно числами от 1 до N.

С помощью своего друга Ровера, который работал в банке сторожевым псом, они добыли ключи от всех ячеек, а так же узнали, как много ценностей хранится в каждой ячейке.

Чтобы не вызывать лишних подозрений, Клиппи и Мерлин решили ограбить всего две ячейки — по одной на каждого. Также, чтобы охрана банка не почуяла неладного, они решили работать далеко друг от друга — между ними должно быть не меньше K банковских ячеек.

Входные данные

В первой строке вводятся два числа — N ( 2 ≤N≤ 105) и K (0 ≤K<N− 1) соответственно. В второй строке вводятся N чисел ai(0 ≤ai≤ 109) — стоимости хранимых ценностей в ячейках от 1 до N соответственно.

Выходные данные

Выведите два числа в возрастающем порядке — номера ячеек, которые нужно ограбить, чтобы суммарно украсть как можно более дорогие ценности, не вызвав при этом лишних подозрений. Если вариантов несколько выберите тот, в котором меньший номер вскрываемой ячейки был как можно ближе к единице, чтобы в экстренном случае покинуть банк как можно скорее. Если и таких вариантов несколько, выберите тот, в котором и больший номер вскрываемой ячейки был как можно меньше.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.03.2020, 13:03
Ответы с готовыми решениями:

Клиппи и Мерлин грабят банк
Привет всем. Решаю такую задачу: Клиппи и Мерлин решили грабить банк «Документы», который представляет из себя N расположенных в ряд...

Клиппи и Мерлин грабят банк
Клиппи и Мерлин решили грабить банк «Документы», который представляет из себя N расположенных в ряд банковских ячеек, пронумерованных...

Клиппи и Мерлин грабят банк
Решаю задачу по программированию. Условие: Клиппи и Мерлин решили грабить банк «Документы», который представляет из себя N...

31
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
30.03.2020, 16:47
Студворк — интернет-сервис помощи студентам
klopp, с формулировкой задачи плохо вяжется - это я про "суммарно украсть как можно более дорогие ценности". Ну ок. Оттолкнемся от этого - чуть позже отпишу вариант. Красиво напишу, понятненько
0
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
30.03.2020, 16:49
мой код выдает на ваш массив [1, 19] (это с +1 к индексам массива)
Qwerty_Wasd, Да, но важнее не попасться охране ))
именно для этого диапазон между ячейками
1
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
30.03.2020, 17:16
Цитата Сообщение от klopp Посмотреть сообщение
Да, но важнее не попасться охране
В связи с короновирусом соблюдать дистанцию K метров.
2
30.03.2020, 17:19

Не по теме:


Цитата Сообщение от amr-now Посмотреть сообщение
В связи с короновирусом соблюдать дистанцию K метров.
и на ограбление идти строго в медицинских масках))

0
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
30.03.2020, 18:17
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
const n = 50;
const k = 32;
const rand = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min;
// ячейки с деньгами
let cells = Array.from(new Array(n), (_, i) => [rand(1, 109), i])
    .sort((a, b) => b[0] === a[0] ? a[1] - b[1] : b[0] - a[0]);
let result = [];
end:
    for (let v1, i = 0; i < n; i++) {
        v1 = cells[i];
        for (let v2, j = i + 1; j < n; j++) {
            v2 = cells[j];
            if (Math.abs(v1[1] - v2[1]) >= k) {
                result = [v1, v2];
                break end;
            }
        }
    }
 
console.log(result);
console.log(cells);
полное решение, не претендую на оптимальность
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
30.03.2020, 20:29
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
второй ячейки просто нет. Что и выдает мой скрипт в виде -1
[128, 662, 237, 27, 70, 957, 871, 812, 647, 999999999, 4, 295, 797, 325, 556, 150, 170, 805, 11272, 803]
Ответ: 0,18. ТО есть числа 128 + 11272 (максимально доступная сумма по ограничениям в k-позиций)
Если бы была еще одна точно такая же сумма - выбор был бы за той, чья первая ячейка ближе к выходу.

Вторая ячейка должна быть обязательно. Просто алгоритм должен найти любую подходящую пару удовлетворяющую условию к-позиций.
Если шаг равен длине массива - 2 (максимальный шаг), то пара это первый и последний элемент. Других вариантов нет - берем что можем.
Если шаг равен длине массива -3, то пара это либо первый и последний элемент, либо первый и предпоследний, либо второй и последний. В этом случае так как есть варианты должен выбраться максимум из трех доступных. И т.д.
То есть каждый из грабителей должнен унести из банка хоть что-то в любом случае. Даже если это и не будет максимум по сумме - в силу ограничения к-позиций.
По крайней мере, именно так работает код который проходит все тесты по правильным ответам и сложности.
------------------------------
Вы убрали из своей реализации явные циклы, но ввели скрытые (indexOf, max, sort и т.д.) Вы считали какая конечная сложность выходит? Уже далеко не O(N).

---------------------------------------------------------------------------------------
Господа, решения с двумя вложенными циклами можно не приводить. Они слишком очевидны, известны и не являются алгоритмически интересными в силу квадратичной сложности.
2
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
30.03.2020, 21:36
Могу предложить частичное решение для k >= array.length / 2
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
let n = 20;
let k = 10;
 
let arr = [128, 662, 237, 27, 101, 957, 871, 812, 647, 597, 4, 295, 797, 325, 556, 150, 70, 805, 272, 803]
function rob(arr, k) {
    if (k < arr.length / 2) return;
 
    let si1 = 0, sv1 = -1, si2 = -1, sv2 = 0;
    for (let i1 = 0, i2 = k + 1; i2 < arr.length; i1++, i2++) {
        if (sv1 < arr[i1]) {
            sv1 = arr[i1];
            si1 = i1;
        }
        if (sv2 < arr[i2]) {
            sv2 = arr[i2];
            si2 = i2;
        }
    }
    console.log(si1 + 1, si2 + 1); // Для нумерации с единицы
}
 
rob(arr, k);
Как за один проход искать максимумы вперехлёст, не знаю.
Там же пара элементов может находиться недопустимо близко. Напрашивается решение скидывать возможные пары в отдельную коллекцию, но пахнет неправильным решением.
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
31.03.2020, 19:25
Garry Galler, ну вроде по тестам проходит - https://codepen.io/qwerty_wasd/pen/bGdOOgJ
Не O(n), но асимптотика линейная, если грубо O(2n). Форм-фактор тестов оставил для песочницы, ибо не всяк зашедший сюда знает что такое нода и с чем её едят. Комменты на инглише - лень раскладку менять было. За грамматику и семантику сразу прошу прощения - почти нет практики.

JavaScript
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
// set operation object or class - irrelevant for js
let opCellThief = {
 
  // generate array of bank cells with random values
  // 2  <= N <=  105
  cellsBank: Array.from(
    // generate random N - length iterable object
    // use a fixed value like to form a step
    { length: 20 },
 
    // generate in callback random cost of each cell
    function () {
      return Math.floor( Math.random() * 1000 ) + 1;
    }
  ),
 
  // set 10 - we can't using this.cellsBank in TDZ
  // 0 <= K < N− 1
  stepCells: 10,
 
  // get result ~O(2n)
  // arguments:
  // cells - bank of cells
  // _step - step between thieves
  getCellsThief : function (_cells, _step) {
 
    // use Map structure like a couple container "cost -> index"
    let mapCells = new Map();
 
    // set temp array for max values meet conditions of task
    let max = [ 0, 0 ];
 
    // fisrt O(n)
    // here we're filtering array cells by conditions task
    // forming Map structure and find first max value in range 0 + K... length - 1 + K
    for ( let i = 0; i < _cells.length; i++ ) {
 
      if (
        _cells[i + _step + 1] ||
        _cells[_cells.length - i + _step]
      ) {
 
        if (max[0] !== _cells[i]) {
          mapCells.set(_cells[i], i);
        }
 
        if (max[0] < _cells[i]) {
          max[0] = _cells[i];
        }
 
      }
    }
 
    // second O(n)
    // find second max value by conditions task
    for (let i = 0; i < _cells.length; i++) {
 
      if (
        max[1] < _cells[i] &&
        Math.abs(
          mapCells.get( max[0] ) - ( mapCells.get( _cells[i] ) )
        ) > _step) {
 
        max[1] = _cells[i];
 
      }
 
      // check the double max
      // upon coincidence extends max[]
      if (
        max[0] === _cells[i] &&
        Math.abs( i - mapCells.get(_cells[i]) ) > _step
      ) {
 
        let tmp = new Map();
        max.push(tmp.set(_cells[i], i));
        tmp = null;
      }
 
    }
 
    //console.log(mapCells);
 
    // returning indexes's
    // the template literals & ternary operation makes this line longer - no sense use  if...else
    return `\[${ _cells }\]\; step = ${ _step }\; costly -  ${ mapCells.get(max[0]) } and ${ max.length > 2 ? max[2].get(max[0]) : mapCells.get(max[1]) }`;
  },
 
};
 
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
 
// Tested
 
console.clear();
 
console.log(opCellThief.getCellsThief(opCellThief.cellsBank, opCellThief.stepCells));
console.log(opCellThief.getCellsThief([128, 662, 237, 27, 101, 957, 871, 812, 647, 597, 4, 295, 797, 325, 556, 150, 70, 805, 272, 803], 2)); // 5 and 17
console.log(opCellThief.getCellsThief([128, 662, 237, 27, 70, 957, 871, 812, 647, 1597, 4, 295, 797, 325, 556, 150, 170, 805, 11272, 803], 17)); // 0 and 18
console.log(opCellThief.getCellsThief([128, 662, 237, 27, 70, 957, 871, 812, 647, 20000, 4, 295, 797, 325, 556, 150, 170, 805, 11272, 803], 2)); // 9 and 18
console.log(opCellThief.getCellsThief([128, 662, 237, 27, 70, 957, 871, 812, 647, 11272, 4, 295, 797, 325, 556, 150, 170, 805, 11272, 803], 2)); // 9 and 18
 
 
for (let z = 10; z < 95; z++) {
  console.log(
    opCellThief.getCellsThief(
      // generate array
      // length 20+
      Array.from(
        { length: 20 + parseInt(z / 5) },
        function () {
          return Math.floor( Math.random() * 1000 ) + 1;
        }
        // iterate step 2...18
      ), parseInt(z / 5)
    )
  );
};
Добавлено через 3 минуты

Не по теме:

Потом, как посвободнее буду - почищу код маленько ... в своей манере


Не по теме:

А то с этим coronavirinae столько оказывается дел по дому



Добавлено через 5 минут
Garry Galler, да и чуть не забыл - если не трудно, покажите пожалуйста решение на которое вы ориентировались.
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
31.03.2020, 21:41
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
покажите пожалуйста решение на которое вы ориентировалис
В С++ исходнике
В Python варианте
В этом же топике есть и мой личный вариант с сортировкой, но он хотя и быстро работает, все-таки оказался в том виде неверным.
Я его позже допилил до правильного, но только за счет усложнения асимптотики.

Добавлено через 10 минут
P.S. Да, есть еще определенная уверенность, что можно сделать ровно за один цикл. Но она пока не допиливается... :-)
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
31.03.2020, 21:42
Цитата Сообщение от Garry Galler Посмотреть сообщение
Но она пока не допиливается..
Попробую позже, но у меня такой уверенности нет
0
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
02.04.2020, 03:17
JavaScript
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
const n = 20;
const k = 7;
const c = n - k;
const t = k - 1;
const maxIdx = n - 1;
const left = new Array(n);
const right = new Array(n);
const result = {sum: 0, left: 0, right: 0};
const rand = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min;
const arr = Array.from(new Array(n), _ => rand(1, 100));
 
left[0] = [arr[0], 0];
right[maxIdx] = [arr[maxIdx], maxIdx];
 
for (let i1 = 1, i2 = n - 2; i1 < n; i1++, i2--) {
    left[i1] = arr[i1] > left[i1 - 1][0] ? [arr[i1], i1] : left[i1 - 1];
    right[i2] = arr[i2] >= right[i2 + 1][0] ? [arr[i2], i2] : right[i2 + 1];
}
 
for (let sum, dist, i = 0; i < c; i++) {
    sum = left[i][0] + right[i + t][0];
    dist = left[i][1] + right[i + k][1];
    if (sum > result.sum && dist > t) {
        result.sum = sum;
        result.left = left[i][1];
        result.right = right[i + k][1];
    }
}
console.log(arr);
console.log(result);
console.log(arr[result.left], arr[result.right]);
хорошая задачка :-)
0
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
02.04.2020, 12:42
JavaScript
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
const n = 12;
const k = 8;
const c = n - k;
const t = k - 1;
const maxIdx = n - 1;
const left = new Array(n);
const right = new Array(n);
const rand = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min;
const arr = Array.from(new Array(n), _ => rand(1, 100));
let result = {sum: 0, left: 0, right: 0};
left[0] = [arr[0], 0];
right[maxIdx] = [arr[maxIdx], maxIdx];
 
for (let i1 = 1, i2 = n - 2; i1 < c; i1++, i2--) {
    left[i1] = arr[i1] > left[i1 - 1][0] ? [arr[i1], i1] : left[i1 - 1];
    right[i2] = arr[i2] >= right[i2 + 1][0] ? [arr[i2], i2] : right[i2 + 1];
}
 
for (let sum, z = k, i = 0; i < c; i++, z++) {
    sum = left[i][0] + right[z][0];
    if (sum > result.sum && left[i][1] + right[z][1] > t) {
        result = {sum, left: left[i][1], right: right[z][1]};
    }
}
console.log(arr);
console.log(result);
console.log(arr[result.left], arr[result.right]);
console.log(`distance: ${result.right - result.left}`);}
так лучше будет
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.04.2020, 12:42
Помогаю со студенческими работами здесь

Клиппи и Мерлин грабят банк
Клиппи и Мерлин грабят банк Клиппи и Мерлин решили грабить банк, который представляет собой N расположенных в ряд банковских ячеек,...


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

Или воспользуйтесь поиском по форуму:
32
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в конфигурации КА2. Данные берутся из регистра сведений, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru