成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JS 多發(fā)票多金額分配

source / 1644人閱讀

摘要:原來的需求是這樣的,用戶生成了元訂單,需要元的發(fā)票去抵消,發(fā)票數(shù)和訂單數(shù)不受限制,將問題擬物化,訂單可以想象成杯子,發(fā)票可以想象成水,現(xiàn)在要把水分配到每個杯子中去我們先記錄每個杯子的起始值和結(jié)束值,還有當(dāng)前值,起始值當(dāng)前杯子的起始值加上上一

原來的需求是這樣的,用戶生成了400元訂單,需要400元的發(fā)票去抵消,發(fā)票數(shù)和訂單數(shù)不受限制,

將問題擬物化,訂單可以想象成杯子,發(fā)票可以想象成水,現(xiàn)在要把水分配到每個杯子中去
我們先記錄每個杯子的起始值和結(jié)束值,還有當(dāng)前值,起始值(start)=當(dāng)前杯子的起始值加上上一個杯子的結(jié)束值,結(jié)束值(end)即起始值加上杯子的容量,當(dāng)前值(index)即當(dāng)前杯子中的水,如果大于杯子的容量則倒下一個杯子,依次循環(huán),所以其實整個倒水可以看做一個大杯子,按階段倒水,每次記錄倒水的index(即當(dāng)前(或者當(dāng)次)杯子中的水即可)

現(xiàn)在假設(shè)a杯50L, b杯20L
假如第一次倒, a[0, 50]杯子倒?jié)M,剩余20;index = 50 , start = 0 , end = 50;
第二次倒b杯[50, 70], 首先拿上一下剩余的20L, 剛好倒?jié)M,index = 20; start = 50 ,end = 70
依次類推

話不多說,上代碼

export function getItemDistribution(a, b, waterKey, cupKey, policyId) {

    class ItemDistribution { 
        cupList = [];
        result = [];

        constructor(list, maps) {
            this.waterKey = waterKey;
            this.cupKey = cupKey;
            this.policyId = policyId;
            this.sort(list, maps);
            this.init(list);
        }

        sort(list, maps) {
            let {waterKey, cupKey} = this;
            if (waterKey) {
                list = list.sort((a, b) => a[waterKey] - b[waterKey]);
            } else {
                list = list.sort((a, b) => a - b);
            }
            if (cupKey) {
                maps = maps.sort((a, b) => a[cupKey] - b[cupKey]);
            } else {
                maps = maps.sort((a, b) => a - b);
            }
            this.list = list;
            this.maps = maps;
            return {list, maps}
        }

        init(list) {
            if (list == null || list.length <= 0) {
                return;
            }
            let start = 0, end = 0, index = 0;
            let {waterKey} = this;
            list.forEach((item, id) => {
                if (!waterKey) {
                    this.result[id] = [];
                }
                let water = waterKey ? item[waterKey] : item;
                end = start + Number(water);
                this.entry({start, index, end});
                start = end;
            });
            this.dispatchMaps();
        }

        entry({start, index, end}) {
            index = start;
            this.cupList.push({start, end, index})
        }

        dispatchMaps() {
            function isEmpty(o) {
                switch (JSON.stringify(o)) {
                    case "null":
                    case undefined:
                        return true;
                    case "[]":
                        return true;
                }
                return false;
            }

            let {maps = [], cupList, cupKey} = this;
            if (isEmpty(cupList) || isEmpty(maps)) return false;
            maps.forEach((item, id) => {
                let cup = cupKey ? item[cupKey] : item;
                this.dispatchCup({item: cup, id});
            });
        }

        getCup() {
            function isEqual(a, b) {
                return String(a.toFixed(2)) !== String(b.toFixed(2));
            }

            let {cupList} = this;
            for (let i = 0; i < cupList.length; i++) {
                let item = cupList[i];
                if (isEqual(item.end, item.index)) {
                    return {cup: item, cupIndex: i};
                }
            }
            return {};
        }

        dispatchCup({item, id}) {
            let {cup, cupIndex} = this.getCup();
            if (!cup) return false;
            let {index, end} = cup;
            let remain = end - index;
            let {waterKey, list, policyId, maps} = this;
            if (remain > item) {
                cup.index = cup.index + item;
                waterKey ? this.result.push({
                    ...list[cupIndex],
                    [waterKey]: item,
                    [policyId]: maps[id][policyId]
                }) : this.result[id].push(item);
                return false;
            } else {
                cup.index = cup.end;
                waterKey ? this.result.push({
                    ...list[cupIndex],
                    [waterKey]: remain,
                    [policyId]: maps[id][policyId]
                }) : this.result[id].push(remain);
                item -= remain;
                this.dispatchCup({item, id})
            }
        }
    }

    return new ItemDistribution(a, b);
}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96027.html

相關(guān)文章

  • 用css動態(tài)實現(xiàn)圓環(huán)百分比分配——初探css3動畫

    摘要:鑫大佬這篇博文的重點還是在漸變,而我需要動態(tài)平緩連續(xù)得實現(xiàn)顏色的分配,比如原本整個環(huán)是綠色,然后慢慢地被紅色占了,而且整個過程要平滑。 最近的小程序項目有個設(shè)計圖要求做一個圓環(huán),兩種顏色分配,分別代表可用金額和凍結(jié)金額。要是就直接這么顯示,感覺好像挺沒水平??于是我決定做個動態(tài)! 在mdn把新特性gradients(漸變)、transitions(過渡)、 animations(動畫)...

    cheukyin 評論0 收藏0
  • 用css動態(tài)實現(xiàn)圓環(huán)百分比分配——初探css3動畫

    摘要:鑫大佬這篇博文的重點還是在漸變,而我需要動態(tài)平緩連續(xù)得實現(xiàn)顏色的分配,比如原本整個環(huán)是綠色,然后慢慢地被紅色占了,而且整個過程要平滑。 最近的小程序項目有個設(shè)計圖要求做一個圓環(huán),兩種顏色分配,分別代表可用金額和凍結(jié)金額。要是就直接這么顯示,感覺好像挺沒水平??于是我決定做個動態(tài)! 在mdn把新特性gradients(漸變)、transitions(過渡)、 animations(動畫)...

    stormgens 評論0 收藏0
  • 多發(fā)短信的平臺如何選擇?

    摘要:當(dāng)今社會是一個信息化的時代,多企業(yè)苦于找不到一個合適的短信群發(fā)平臺,選擇一個合適的短信服務(wù)平臺不僅可以高效推送,還可以節(jié)約成本。最后看選擇的公司價錢是否合適,性價比高不高,如何計費市面上高的七八分,低的三四分分,但太低的可能會有風(fēng)險。當(dāng)今社會是一個信息化的時代,多企業(yè)苦于找不到一個合適的短信群發(fā)平臺,選擇一個合適的短信服務(wù)平臺不僅可以高效推送,還可以節(jié)約成本。下面我們就來了解下如何選擇一個合...

    3119555200 評論0 收藏0
  • java并發(fā)編程學(xué)習(xí)18--最迷你的搶紅包

    摘要:業(yè)務(wù)分析要完成搶紅包的功能重點有兩個多線程并發(fā)修改數(shù)據(jù)紅包現(xiàn)金分配算法類設(shè)計用戶對象包含用戶名稱,所搶到的金額,最后的提示文言字段搶紅包的用戶用戶昵稱用戶搶到的金額用戶獲得系統(tǒng)提示文言并發(fā)訪問的共享紅包對象這個對象包含了預(yù)分配的所有小紅包并 【業(yè)務(wù)分析 要完成搶紅包的功能重點有兩個: 多線程并發(fā)修改數(shù)據(jù) 紅包現(xiàn)金分配算法 【類設(shè)計 用戶對象:包含用戶名稱,所搶到的金額,最后的提示文...

    caohaoyu 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<