摘要:数据集合基础数据保存基本数据排序操作校验越大优先级越高多属性比较原始数据季度相关数据金额保留的小数位数增加平均值春夏秋冬构造自增长度代码的健壮性,很大一部分工作在入口的严格把控入参的处理这里会有一个通用的工具方法集合
extensions is an Array and each item has such format:
{firstName: "xxx", lastName: "xxx", ext: "xxx", extType: "xxx"}
lastName, ext can be empty, extType can only has "DigitalUser", "VirtualUser","FaxUser","Dept","AO".
Question 1: sort extensions by "firstName" + "lastName" + "ext" ASC
Question 2: sort extensions by extType follow these orders ASC
DigitalUser < VitrualUser < FaxUser < AO < Dept.
/* * 数据集合 * 基础数据保存 + 基本数据排序操作 */ class ExtensionsSort { constructor (data = []) { this.data = data; this.extTypeList = ["DigitalUser", "VirtualUser","FaxUser", "AO", "Dept"]; } // 校验extType checkExtType (item) { if (this.extTypeList.indexOf(item) === -1) { console.log("extType can only has "DigitalUser", "VirtualUser","FaxUser","Dept","AO""); return false; } return true; } compareExtType (type1, type2, isAsc) { // extTypeList index越大优先级越高 let idx1 = this.extTypeList.indexOf(type1); let idx2 = this.extTypeList.indexOf(type2); if (idx1 === -1 || idx2 === -1) { console.log("extType can only has "DigitalUser", "VirtualUser","FaxUser","Dept","AO""); } return this.compare(idx1, idx2, isAsc); } // 多属性比较 compareAttrs (el1, el2, attrs) { // attrs: [{key: "attr1", isAsc: false}] let res = []; let len = attrs.length; for (let i = 0; i < len; i++) { let val = this.compare(el1[attrs[i].key], el2[attrs[i].key], attrs[i].isAsc); res.push(val); if (val === 1 || val === -1) break; } for (let j = 0; j < res.length; j++) { if (res[j] === 1 || res[j] === -1) return res[j]; } return 0; } compare (item1, item2, isAsc) { if (item1 > item2) { return (isAsc ? 1 : -1); } else if (item1 < item2) { return (isAsc ? -1 : 1); } else { return 0; } } } function sortExtensionsByName(extensions) { let es = new ExtensionsSort(extensions); let attrs = [ { key: "firstName", isAsc: true }, { key: "lastName", isAsc: true }, { key: "ext", isAsc: true } ] extensions.sort((a, b) => { return es.compareAttrs(a, b, attrs); }); return extensions; } function sortExtensionsByExtType(extensions, isAsc = true) { let es = new ExtensionsSort(extensions); extensions.sort((a, b) => { return es.compareExtType(a, b, isAsc); }); return extensions; }
saleItems is an Array has each item has such format:
{ month: n,//[1-12], date: n, //[1-31], transationId: "xxx", salePrice: number}
Question 3: write a function to calculate and return a list of total sales (sum) for each quarter, expected result like:
[{quarter: 1, totalPrices: xxx, transactionNums: n},{....}]
Question 4: write a function to calculate and return a list of average sales for each quarter, expected result like:
[{quarter: 1, averagePrices: xxx, transactionNums: n},{....}]
class QuarterData { constructor(saleItems = [], digits = 2){ // 原始数据 this.saleItems = saleItems; // 季度相关数据 this.sumOfQuarterItems = []; //金额保留的小数位数 this.digits = Math.pow(10, digits); this.quarterData(); return this; } quarterData () { let res = []; this.saleItems.forEach((item) => { let quarterId = this.getQuarter(item.month).quarter; if (!res[quarterId]) { res[quarterId] = { quarter: quarterId, totalPrices: 0, transactionNums: 0 }; } res[quarterId].totalPrices = (res[quarterId].totalPrices*this.digits + item.salePrice*this.digits)/this.digits; res[quarterId].transactionNums += 1; }); this.sumOfQuarterItems = res.filter((item) => { // 增加平均值 item ? (item.averagePrices = (item.totalPrices*this.digits / item.transactionNums) / this.digits) : ""; return item !== undefined; }); return this; } // quarter getQuarter (month) { let spring = 0; //春 let summer = 3; //夏 let fall = 6; //秋 let winter = 9; //冬 if (month < summer) { return { key: "spring", quarter: 1 }; } if (month < fall) { return { key: "summer", quarter: 2 }; } if (month < winter) { return { key: "fall", quarter: 3 }; } return { key: "winter", quarter: 3 }; } } function sumByQuarter(saleItems) { let sum = new QuarterData(saleItems).sumOfQuarterItems; let res = []; sum.forEach((item) => { res.push({ quarter: item.quarter, totalPrices: item.totalPrices, transactionNums: item.transactionNums }); }); return res; } function averageByQuarter(saleItems) { let average = new QuarterData(saleItems).sumOfQuarterItems; let res = []; average.forEach((item) => { res.push({ quarter: item.quarter, averagePrices: item.averagePrices, transactionNums: item.transactionNums }); }); return res; }
Question 5: please create a tool to generate Sequence Expected to be used like:
var sequence1 = new Sequence();
sequence1.next() --> return 1;
sequence1.next() --> return 2;
in another module:
var sequence2 = new Sequence();
sequence2.next() --> 3;
sequence2.next() --> 4;
let SequenceConfig = { idx: 0 }; class Sequence{ // 构造 constructor(incr = 1){ // 自增长度 this.incr = incr; this.config = SequenceConfig; } incrIdx () { this.config["idx"] += this.incr; return this.config["idx"]; } next () { let idx = this.increaseIdx(); return idx; } }
Question 6:
AllKeys: 0-9; usedKeys: an array to store all used keys like [2,3,4]; We want to get an array which contains all the unused keys,in this example it would be: [0,1,5,6,7,8,9]
代码的健壮性,很大一部分工作在入口的严格把控【入参的处理】
这里会有一个通用的工具方法集合
let _utils = { isNumber (data) { return Object.prototype.toString.call(data) === "[object Number]"; }, isArray (data) { return Object.prototype.toString.call(data) === "[object Array]"; }, createArray (number = 9) { let arr = []; for (let i = 0; i <= number; i++) { arr.push(i); } return arr; } }; function getUnUsedKeys (allKeys = 9, usedKeys = []) { _utils.isNumber(allKeys) ? allKeys = _utils.createArray(allKeys) : ""; if (_utils.isArray(allKeys)) { return allKeys.filter((item) => { return usedKeys.indexOf(item) === -1; }); } else { console.log("allKeys should be an array or number"); } }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/90315.html
摘要:题目一题目什么是闭包,为什么要用它网址博客题目二题目的实现原理网址题目三题目是什么的交互模型同步和异步的区别如何解决跨域问题网址题目四题目如何解决跨域问题网址题目五题目原生封装处理兼容网址 题目一:题目:什么是闭包(closure),为什么要用它?网址:http://bbs.daxiangclass.com/?...博客:https://www.jianshu.com/p/6fa......
摘要:定义变量如果不使用则变量为为全局作用域。当然严格模式是禁止这样做的。遵循词法作用域原则,其中后两题来源于权威指南。非箭头函数下的指向运行时所在作用域。中逗号操作符会从左到右计算它的操作数,返回最后一个操作数的值。原文发表于我的博客 (function(){ var a = b =1; })() console.log(b) 答案:1。定义变量如果不使用 var 则变量为为全局作...
阅读 3734·2021-11-24 09:39
阅读 1892·2021-11-16 11:45
阅读 622·2021-11-16 11:45
阅读 1043·2021-10-11 10:58
阅读 2487·2021-09-09 11:51
阅读 1948·2019-08-30 15:54
阅读 698·2019-08-29 13:13
阅读 3476·2019-08-26 12:18