Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 12.05.2019, 21:14
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,105

Alexandroppolus,
почему при М = 6 у вас иной подсчёт, чем при М = 5?

Последний раз редактировалось рони, 12.05.2019 в 21:22.
Ответить с цитированием
  #12 (permalink)  
Старый 12.05.2019, 21:57
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,105

Сообщение от Alexandroppolus
(предполагаем, что самый младший разряд - первый, т.е. нечетный):
function calculation(M,N){
    var количество = 0;
    for(var k = Math.pow(10, M - 1); k <= Math.pow(10, M) - 1; k++){
        const число = String(k);
        const цифры = [...число];
        var сумма = 0;
        for(var i = 0; i < M; i += 2) {
                сумма += +цифры[i];
        }
        if(сумма === N) количество++;
    }
    return количество;
}

alert(calculation(5,5) * 10 === calculation(6,5));

10!!! а не 9

Последний раз редактировалось рони, 12.05.2019 в 22:04.
Ответить с цитированием
  #13 (permalink)  
Старый 12.05.2019, 22:04
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,105

Alexandroppolus,
не учёл что речь была о младшем разряде, считал первую цифру нечётной.
вопрос исчерпан.
Ответить с цитированием
  #14 (permalink)  
Старый 12.05.2019, 23:30
Аватар для Alexandroppolus
Профессор
Отправить личное сообщение для Alexandroppolus Посмотреть профиль Найти все сообщения от Alexandroppolus
 
Регистрация: 25.10.2016
Сообщений: 1,012

(1<N<90, 5<M<20)
поскольку при этих ограничениях результат не всегда влезает в Number.MAX_SAFE_INTEGER, то возвращаем его в виде строки

https://jsfiddle.net/bw783h4j/

Последний раз редактировалось Alexandroppolus, 12.05.2019 в 23:42.
Ответить с цитированием
  #15 (permalink)  
Старый 13.05.2019, 00:39
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,105

Alexandroppolus,
ничего не понял, но спасибо!
Ответить с цитированием
  #16 (permalink)  
Старый 14.05.2019, 18:10
Интересующийся
Отправить личное сообщение для ProgYoung Посмотреть профиль Найти все сообщения от ProgYoung
 
Регистрация: 08.05.2019
Сообщений: 25

Alexandroppolus,
Спасибо большое за ваш труд!
Не могли бы вы еще раз попроще объяснить, что происходит в функции sumCount() ?
Ответить с цитированием
  #17 (permalink)  
Старый 14.05.2019, 18:32
Аватар для Alexandroppolus
Профессор
Отправить личное сообщение для Alexandroppolus Посмотреть профиль Найти все сообщения от Alexandroppolus
 
Регистрация: 25.10.2016
Сообщений: 1,012

ProgYoung,
функциия sumCount определяет, сколькими способами можно разложить число n на m слагаемых, так что каждое слагаемое будет в пределах от 0 до 9, а первое слагаемое - от f до 9. Она работает рекурсивно - в цикле перебирает все возможные значения первого слагаемого и на каждой итерации считает sumCount(m-1, n-i) - т.е. если первое число взять равным i, то сколько будет вариантов по остальным числам и оставшейся сумме. Это всё суммируется.

Массив saved - для сохранения значений sumCount(m, n), т.к. они часто будут повторяться: например, если первые два слагаемых равны (1, 7), (2, 6) и т.д., то оставшаяся сумма одинакова.

т.е. sumCount как раз и делает подсчет вариантов для нечетных разрядов, коих оказалось примерно половина от всех разрядов числа.
Ответить с цитированием
  #18 (permalink)  
Старый 14.05.2019, 18:57
Интересующийся
Отправить личное сообщение для ProgYoung Посмотреть профиль Найти все сообщения от ProgYoung
 
Регистрация: 08.05.2019
Сообщений: 25

Alexandroppolus,
почему первое слагаемое от f, а не от 1? Еще у меня так и не выводит ответ, хотя вроде все правильно (я сохраняю текстовый документ, как .html и открываю в гугле):

<!DOCTYPE html>
<html>
<head>
 <META http-equiv="Content-Type" content="text/html; charset=windows-1251"/>
 <title></title>
</head>
<body>

<p>Введите число N - сумма чисел в нечетных разрядах:</p>
<input type="text" id="n" size="10" maxlength="15"/>
<p>Введите число M (M-значные числа):</p>
<input type="text" id="m" size="10" maxlength="15"/>
<p id="solution">Решение</p>
<p><textarea id="solve" rows="15" cols="40"></textarea></p>

<script type="text/javascript">

var calculation = function() {
    function sumCount(f, m, n, saved) {
        if (m < 2) {
            return n < 10 && n >= f ? 1 : 0;
        }
        if (n < 1) {
            return 1 - f;
        }
        if (saved[m][n] >= 0) {
            return saved[m][n];
        }
        var c = 0, last = Math.min(n, 9);
        for (var i = f; i <= last; ++i) {
            c += sumCount(0, m - 1, n - i, saved);
        }
        return saved[m][n] = c;
    }

    function calc(M, N) {
        var saved = [];
        var digs = Math.ceil(M / 2);
        for (var i = 0; i <= digs; ++i) {
            saved[i] = new Array(N + 1);
            for (var j = 0; j <= N; ++j) {
                saved[i][j] = -1;
            }
        }
        var count = sumCount(M % 2, digs, N, saved);
        var suf = Array(Math.ceil(M / 2)).join('0');
        var k = M % 2 ? 1 : 9;
        
        return count ? (count * k) + suf : '0';
    }

    return calc;
};

 document.getElementById("solution").onclick = function() {

   var M = parseInt(document.getElementById("id_m").value, 10);
   var N = parseInt(document.getElementById("id_n").value, 10);

   document.getElementById("solve").innerHTML = calculation(M, N);

 }
</script>
</body>
</html>

Последний раз редактировалось ProgYoung, 14.05.2019 в 19:11.
Ответить с цитированием
  #19 (permalink)  
Старый 14.05.2019, 23:18
Аватар для Alexandroppolus
Профессор
Отправить личное сообщение для Alexandroppolus Посмотреть профиль Найти все сообщения от Alexandroppolus
 
Регистрация: 25.10.2016
Сообщений: 1,012

Сообщение от ProgYoung
почему первое слагаемое от f, а не от 1?
f по факту может быть 0 или 1, функция вызывается так: sumCount(M % 2, digs, N, saved);
Сообщение от ProgYoung
Еще у меня так и не выводит ответ, хотя вроде все правильно
id у элементов не совпадают с теми, которые в getElementById используются.

Последний раз редактировалось Alexandroppolus, 14.05.2019 в 23:22.
Ответить с цитированием
  #20 (permalink)  
Старый 15.05.2019, 07:49
Интересующийся
Отправить личное сообщение для ProgYoung Посмотреть профиль Найти все сообщения от ProgYoung
 
Регистрация: 08.05.2019
Сообщений: 25

Alexandroppolus,
тьфу ты... Спасибо большое!)
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Просмотрела исходик jQuery Откорректируйте где не верно taksebe jQuery 5 23.11.2018 22:42
Вот такое задание, но я только в начале пути вэб разработки, подскажите как? Dixlofos Общие вопросы Javascript 31 22.10.2018 01:48