Показать сообщение отдельно
  #22 (permalink)  
Старый 31.01.2022, 20:09
Интересующийся
Отправить личное сообщение для DzonyB Посмотреть профиль Найти все сообщения от DzonyB
 
Регистрация: 28.01.2022
Сообщений: 16

Сообщение от рони Посмотреть сообщение
не знаю.
Рони,Выкладываю свои потуги. В глубине души понимаю , что кривовато , но лучше сделать ума , не хватило .
Недостатки ,
1. При указании суммы подгруппы не elem_sum+1 , т.е ne 11 , a 10 , разбивает только на подгруппы с суммой 10 , а в основном массиве остается 1 .
2. Остается пустой массив.
Если не трудно , прошу покритиковать , а еще лучше подправить . Я с удовольствием поизучаю рабочий вариант.

<script>

    const webstore = new Vue({
        el: '#app',
        data() {
            return {

                array_in: [1, 2, 4, 7, 1, 6, 2, 8],

                array_original: [],

                count_group: 3,

                array_out: [],

            }
        },

        created() {

            this.getArray(this.array_in, this.count_group);
        },

        methods: {

            getArray(arr, n) {

                let arr_out = [];
                n = this.count_group;
                let arr_clone = [arr_out];
                let arr_length = arr.length;

                this.array_original = Array.from(this.array_in);

                arr.sort((a, b) => b - a);

               let elem_sum = parseInt(arr.reduce((x, y) => x + y) / n);

                for (let i = 0; i <= n - 1; i++) {

                    for (let i = 0; i <= arr_length - 1; i++) {

                        if (arr_out.reduce((x, y) => x + y, 0) + arr[i] <= elem_sum + 1) {
                            arr_out.splice(0, 0, arr[i]);
                            delete arr[i];
                        }
                    }

                    if (arr_out.reduce((x, y) => x + y, 0) <= elem_sum + 1) {
                        arr_out = [] , arr_clone.push(arr_out);
                    }
                }
                this.array_out = arr_clone;

            }// End Get array
        },

    }); //End Vue

</script>
Ответить с цитированием