您现在的位置: 首页 资讯 > > 正文
2023-06-18:给定一个长度为N的一维数组scores, 代表0~N-1号员工的初始得分, scores[i] = a, 表示i号员工一开始得分是a, 给定一个长度为M的二维数组operatio
发布时间:2023-06-18 18:29:57 来源:博客园

2023-06-18:给定一个长度为N的一维数组scores, 代表0~N-1号员工的初始得分,


【资料图】

scores[i] = a, 表示i号员工一开始得分是a,

给定一个长度为M的二维数组operations,

operations[i] = {a, b, c}。

表示第i号操作为 :

如果a==1, 表示将目前分数

如果a==2, 表示将编号为b的员工,分数改成c,

所有操作从0~M-1, 依次发生。

返回一个长度为N的一维数组ans,表示所有操作做完之后,每个员工的得分是多少。

1 <= N <= 10的6次方,

1 <= M <= 10的6次方,

0 <= 分数 <= 10的9次方。

来自TikTok美国笔试。

答案2023-06-18:

具体步骤如下:

1.创建一个长度为N的一维数组scores,表示每个员工的初始得分。

2.创建一个长度为M的二维数组operations,表示操作序列。

3.定义一个函数operateScores2来处理操作序列。

4.初始化一个节点数组nodes,用于存储每个员工的节点信息。

5.初始化一个空的得分和桶的映射表scoreBucketMap

6.遍历scores数组,为每个得分值创建一个桶,并将对应的员工节点添加到桶中。

7.遍历operations数组,处理每个操作。

8.对于类型为1的操作,获取小于当前得分的最大得分值floorKeyV,然后将它们的桶合并到新的得分值对应的桶中。

9.对于类型为2的操作,获取该员工节点,并将其从原来的桶中移除,然后添加到新的得分值对应的桶中。

10.遍历得分和桶的映射表scoreBucketMap,将桶中的员工节点按照顺序取出,更新到结果数组ans中。

11.返回最终的结果数组ans

12.进行功能测试和性能测试。

时间复杂度分析:

遍历scores数组并创建桶,时间复杂度为O(N)。

遍历operations数组,每个操作的时间复杂度为O(logN)(由于使用了有序映射表来实现桶,检索操作的时间复杂度为O(logN))。

遍历得分和桶的映射表scoreBucketMap,每个桶中的员工节点数量为O(1),遍历的时间复杂度为O(N)。

总体时间复杂度为O(N + KlogN),其中K为操作序列的长度。

空间复杂度分析:

创建一个长度为N的数组scores,空间复杂度为O(N)。

创建一个长度为M的数组operations,空间复杂度为O(M)。

创建一个长度为N的节点数组nodes,空间复杂度为O(N)。

创建一个有序映射表scoreBucketMap,储存每个得分值对应的桶,空间复杂度为O(N)。

结果数组ans的长度为N,空间复杂度为O(N)。

总体空间复杂度为O(N + M)。

go完整代码如下:
package mainimport ("fmt""math/rand""time")// 桶,得分在有序表里!桶只作为有序表里的value,不作为keytype Bucket struct {head *Nodetail *Node}func NewBucket() *Bucket {head := &Node{index: -1}tail := &Node{index: -1}head.next = tailtail.last = headreturn &Bucket{head: head, tail: tail}}func (b *Bucket) add(node *Node) {node.last = b.tail.lastnode.next = b.tailb.tail.last.next = nodeb.tail.last = node}func (b *Bucket) merge(join *Bucket) {if join.head.next != join.tail {b.tail.last.next = join.head.nextjoin.head.next.last = b.tail.lastjoin.tail.last.next = b.tailb.tail.last = join.tail.lastjoin.head.next = join.tailjoin.tail.last = join.head}}// Node represents a node in the buckettype Node struct {index intlast  *Nodenext  *Node}func (n *Node) connectLastNext() {n.last.next = n.nextn.next.last = n.last}// 暴力方法func operateScores1(scores []int, operations [][]int) []int {n := len(scores)ans := make([]int, n)copy(ans, scores)for _, op := range operations {if op[0] == 1 {for i := 0; i < n; i++ {ans[i] = max(ans[i], op[1])}} else {ans[op[1]] = op[2]}}return ans}// 正式方法func operateScores2(scores []int, operations [][]int) []int {n := len(scores)nodes := make([]*Node, n)scoreBucketMap := make(map[int]*Bucket)for i := 0; i < n; i++ {nodes[i] = &Node{index: i}if _, ok := scoreBucketMap[scores[i]]; !ok {scoreBucketMap[scores[i]] = NewBucket()}scoreBucketMap[scores[i]].add(nodes[i])}for _, op := range operations {if op[0] == 1 {floorKeyV := floorKey(scoreBucketMap, op[1]-1)if floorKeyV != -1 && scoreBucketMap[op[1]] == nil {scoreBucketMap[op[1]] = NewBucket()}for floorKeyV != -1 {scoreBucketMap[op[1]].merge(scoreBucketMap[floorKeyV])delete(scoreBucketMap, floorKeyV)floorKeyV = floorKey(scoreBucketMap, op[1]-1)}} else {cur := nodes[op[1]]cur.connectLastNext()if scoreBucketMap[op[2]] == nil {scoreBucketMap[op[2]] = NewBucket()}scoreBucketMap[op[2]].add(cur)}}ans := make([]int, n)for score, bucket := range scoreBucketMap {cur := bucket.head.nextfor cur != bucket.tail {ans[cur.index] = scorecur = cur.next}}return ans}func floorKey(m map[int]*Bucket, target int) int {for score := range m {if score <= target {return score}}return -1}func max(a, b int) int {if a > b {return a}return b}// RandomScores generates an array of random scoresfunc randomScores(n, v int) []int {scores := make([]int, n)rand.Seed(time.Now().UnixNano())for i := 0; i < n; i++ {scores[i] = rand.Intn(v)}return scores}// RandomOperations generates a 2D array of random operationsfunc randomOperations(n, m, v int) [][]int {operations := make([][]int, m)rand.Seed(time.Now().UnixNano())for i := 0; i < m; i++ {operations[i] = make([]int, 3)if rand.Float32() < 0.5 {operations[i][0] = 1operations[i][1] = rand.Intn(v)} else {operations[i][0] = 2operations[i][1] = rand.Intn(n)operations[i][2] = rand.Intn(v)}}return operations}// IsEqual checks if two arrays are equalfunc isEqual(arr1, arr2 []int) bool {if len(arr1) != len(arr2) {return false}for i := 0; i < len(arr1); i++ {if arr1[i] != arr2[i] {return false}}return true}// Main function for testingfunc main() {N := 1000M := 1000V := 100000testTimes := 100fmt.Println("功能测试开始")for i := 0; i < testTimes; i++ {n := rand.Intn(N) + 1m := rand.Intn(M) + 1scores := randomScores(n, V)operations := randomOperations(n, m, V)ans1 := operateScores1(scores, operations)ans2 := operateScores2(scores, operations)if !isEqual(ans1, ans2) {fmt.Println("出错了!")}}fmt.Println("功能测试结束")fmt.Println("性能测试开始")n := 100000m := 100000v := 100000000scores := randomScores(n, v)operations := randomOperations(n, m, v)fmt.Println("总人数:", n)fmt.Println("操作数:", n)fmt.Println("值范围:", v)start := time.Now()operateScores2(scores, operations)end := time.Now()fmt.Println("运行时间:", end.Sub(start))fmt.Println("性能测试结束")}
c++完整代码如下:
#include #include #include #include #include using namespace std;class Bucket;// Node represents a node in the bucketclass Node {public:    int index;    Node* last;    Node* next;    void connectLastNext() {        last->next = next;        next->last = last;    }};// Bucket, scores stored in a sorted listclass Bucket {public:    Node* head;    Node* tail;    Bucket() {        head = new Node();        tail = new Node();        head->index = -1;        tail->index = -1;        head->next = tail;        tail->last = head;    }    void add(Node* node) {        node->last = tail->last;        node->next = tail;        tail->last->next = node;        tail->last = node;    }    void merge(Bucket* join) {        if (join->head->next != join->tail) {            tail->last->next = join->head->next;            join->head->next->last = tail->last;            join->tail->last->next = tail;            tail->last = join->tail->last;            join->head->next = join->tail;            join->tail->last = join->head;        }    }};vector operateScores1(const vector& scores, const vector>& operations) {    int n = scores.size();    vector ans(scores);    for (const auto& op : operations) {        if (op[0] == 1) {            for (int i = 0; i < n; i++) {                ans[i] = max(ans[i], op[1]);            }        }        else {            ans[op[1]] = op[2];        }    }    return ans;}int floorKey(const map& m, int target);vector operateScores2(const vector& scores, const vector>& operations) {    int n = scores.size();    vector nodes(n);    map scoreBucketMap;    for (int i = 0; i < n; i++) {        nodes[i] = new Node();        nodes[i]->index = i;        if (scoreBucketMap.find(scores[i]) == scoreBucketMap.end()) {            scoreBucketMap[scores[i]] = new Bucket();        }        scoreBucketMap[scores[i]]->add(nodes[i]);    }    for (const auto& op : operations) {        if (op[0] == 1) {            int floorKeyV = floorKey(scoreBucketMap, op[1] - 1);            if (floorKeyV != -1 && scoreBucketMap.find(op[1]) == scoreBucketMap.end()) {                scoreBucketMap[op[1]] = new Bucket();            }            while (floorKeyV != -1) {                scoreBucketMap[op[1]]->merge(scoreBucketMap[floorKeyV]);                scoreBucketMap.erase(floorKeyV);                floorKeyV = floorKey(scoreBucketMap, op[1] - 1);            }        }        else {            Node* cur = nodes[op[1]];            cur->connectLastNext();            if (scoreBucketMap.find(op[2]) == scoreBucketMap.end()) {                scoreBucketMap[op[2]] = new Bucket();            }            scoreBucketMap[op[2]]->add(cur);        }    }    vector ans(n);    for (const auto& entry : scoreBucketMap) {        int score = entry.first;        Bucket* bucket = entry.second;        Node* cur = bucket->head->next;        while (cur != bucket->tail) {            ans[cur->index] = score;            cur = cur->next;        }    }    return ans;}int floorKey(const map& m, int target) {    for (const auto& entry : m) {        int score = entry.first;        if (score <= target) {            return score;        }    }    return -1;}int main() {    int N = 1000;    int M = 1000;    int V = 100000;    int testTimes = 100;    cout << "功能测试开始" << endl;    for (int i = 0; i < testTimes; i++) {        int n = rand() % N + 1;        int m = rand() % M + 1;        vector scores(n);        vector> operations(m, vector(3));        for (int j = 0; j < n; j++) {            scores[j] = rand() % V;        }        for (auto& op : operations) {            if (rand() < 0.5) {                op[0] = 1;                op[1] = rand() % V;            }            else {                op[0] = 2;                op[1] = rand() % n;                op[2] = rand() % V;            }        }        vector ans1 = operateScores1(scores, operations);        vector ans2 = operateScores2(scores, operations);        if (ans1 != ans2) {            cout << "出错了!" << endl;        }    }    cout << "功能测试结束" << endl;    cout << "性能测试开始" << endl;    int n = 1000000;    int m = 1000000;    int v = 1000000000;    vector scores(n);    vector> operations(m, vector(3));    for (int i = 0; i < n; i++) {        scores[i] = rand() % v;    }    for (auto& op : operations) {        op[0] = rand() < 0.5 ? 1 : 2;        op[1] = rand() % n;        op[2] = rand() % v;    }    cout << "总人数: " << n << endl;    cout << "操作数: " << m << endl;    cout << "值范围: " << v << endl;    clock_t start = clock();    operateScores2(scores, operations);    clock_t end = clock();    cout << "运行时间: " << double(end - start) / CLOCKS_PER_SEC << endl;    cout << "性能测试结束" << endl;    return 0;}

标签:

新兴食品现身市场 “植物肉”产品能否“俘获”消费者的胃?

最近一段时间,部分超市和电商平台售卖的植物肉纷纷推出促销优惠活动,销量看涨。不过也有消费者表示,...

绍兴招才引智云对话活动举行 诚邀天下英才“会盟”绍兴

懂人才是大学问,聚人才是大本事,用人才是大智慧。近年来,绍兴市大力实施人才强市战略,持续深化人才...

江苏省自然资源厅出台指导意见 推进老旧小区改造工作

省自然资源厅近日出台《关于大力推进城镇老旧小区改造工作的指导意见》,针对城镇老旧小区改造中规划和...

2021年中国心血管健康指数排名:江苏位列前五

进行了排名,江苏位列前五。北京、上海、江苏等地居民心血管更健康这项发表在《中国疾病预防控制中心周...

科研人员揭示5种豆科植物的核型数据及亲缘关系

近日,四川农业大学林学院副教授罗小梅团队在遗传学领域期刊《基因》(Genes),在线发表了题为《基于5S ...

“烟火气”十足的“江苏味道” 河西CBD顶流商圈开街迎客

开街啦!5月18日上午,在河西CBD金融城融媒路上,2022江苏省新能源汽车&信息消费创新产品推广系列活动启...

首个锌金属的伴侣蛋白诞生 有助于解决缺锌公共卫生问题

据17日发表在《细胞》与《细胞报告》杂志上的两篇论文,美国研究人员发现了第一个锌金属的伴侣蛋白,并...

科学家首次揭示糖尿病卵母细胞起源 有助于减少生育缺陷

5月19日,记者从浙江大学获悉,浙大医学院附属妇产科医院黄荷凤院士团队与中国科学院徐国良院士团队合作...

前4月河北省电信网络诈骗案件发案数连续4个月同比下降

记者从省政府新闻办5月18日举行的河北省打击治理电信网络诈骗犯罪工作新闻发布会上获悉,今年1至4月,全...

重庆:到2025年25个重点领域企业能效全部达到基准水平

3月18日,重庆日报记者从市发展改革委获悉,日前,市发展改革委、市经济信息委、市生态环境局、市市场监...

重磅!2021“发现重庆之美”获奖名单揭晓

3月19日,2021发现重庆之美颁奖典礼在线上举行,最美城市管理人、最美坡坎崖、最美街头绿地、垃圾分类时...

去年重庆回收废弃农膜1.4万吨 农膜回收率达89.31%

3月16日,市五届人大常委会第六十九次主任会议听取了市政府关于《重庆市人大常委会对市人民政府农业面源...

申报分两批!今年国家级博士后科研工作站新设站工作启动

3月19日,重庆日报记者从市人力社保局获悉,为推动产学研深度融合,加强博士后工作平台建设,我市将开展...

浙江鄞州:“水、电、气、数”通办专窗实现城乡公共服务均等化

近日,在宁波市鄞州区邱隘镇公共事务服务中心,66岁的邱隘镇沈家新村居民邱秀月在一个窗口相继办理了不...

打开“浙里办” 浙江1000家农贸市场农产品可线上比价

今天哪个菜场的五花肉最便宜?食品安全抽检结果怎么样?这些问题,浙江居民只需打开浙里办APP上的浙里市场...

浙江鉴湖国家湿地公园规划发布 打造乡村数字旅游

19日上午,鉴湖国家湿地公园规划发布暨东鉴湖农旅观光体验启动仪式在绍兴市越城区陶堰街道举行。当天,...

总投资超10亿元!6个石化装备运维项目在岱山签约

日前,总投资超10亿元的6个石化装备运维项目在岱山经济开发区集中签约。此次签约的项目占地106亩,规划...

如何避免成为“买而不做”的“装备党”祝 杰

自恋是人的天性,人们总是希望自己是更好的,那么自己拥有的事物,也就相应地被自我赋予了更高的价值,...

山西临汾:率先在全省建起农村集体经济开发区

3月17日,临汾市农村集体经济发展(集团)有限公司在临汾经济开发区揭牌。以此为标志,临汾率先在全省建起...

一线工作近22年的缉毒警:我知道坏的是毒品不是人性

  “影子”般的缉毒警:一线工作22年,我知道坏的是毒品不是人性  如果我不继续干,别人也要干,缉...

广东肇庆“毒驾连撞5车致1死”肇事司机被批捕

  1月5日14时30分许,广东肇庆市端州区一男子赵某毒驾连撞5车,致一人死亡。  1月10日,澎湃新闻(ww...

江西最大文物倒卖案宣判:倒卖国家二级文物 9人获刑

  中新网南昌1月10日电 (冷峥嵘 张一怡)江西省共青城市人民法院10日发布消息称,近日,该院依法审结...

青海保障门源地震后生活必需品应急物资

  中新网西宁1月10日电 (记者 孙睿)记者10日从青海省商务厅获悉,青海海北州门源县6 9级地震灾害发...

广西东兴口岸恢复通关 入境需网上预约

  中新社防城港1月10日电 (翟李强)自2022年1月10日零时起,广西东兴口岸和边民互市贸易区恢复人员、...

呼和浩特:寒假期间有条件的学校要开展校内托管服务

  中新网呼和浩特1月10日电 (记者 张林虎)10日,记者从呼和浩特市教育局获悉,在暑假校内托管试点的...

“中国最后一个原始部落”翁丁老寨火灾原因公布

北京市十五届人大五次会议胜利闭幕

天津市委市政府致全市父老乡亲的慰问信:我们一定能够打赢

天津米面油存量由20天提高至30天 超市菜市场进货量翻倍

兰州名师话“美育”:“尚乐立人”分层培优 以“美”润教

子夜直击,天津寒天战“疫”

重庆姐弟被生父扔下坠亡案上诉期结束 一审法院暂未收到两被告人上诉状

天津:划定封控区 全市开展全员核酸检测

江歌母亲江秋莲:尊重法院判决,法律认定在我意料之中

中国边疆“北方第一所”:9名民警守护“生命禁区”

辟谣!网传“封控区管控区相继解封”通知并非西安

河南安阳9日12时至24时新增11例本土确诊病例

老人5折环卫工8折生活困难免费 这家面馆背后有个暖心事

铁路公安以110幅优秀书画作品庆祝人民警察节

本周中东部冷空气频繁 东北等地有降雪

河南新增本土确诊病例60例

“打拐”民警眼里的百态人生:见证一份份不愿放弃的爱

迎腊八北京晴天上线 阵风6至7级体感冻人

多省份倡议春节“非必要不离开”,这地补贴1000元

伪造国家机关证件典型案例发布 有力打击制假贩假行为

15年照顾170多个新生儿 金牌月嫂“漂”到海外去看娃

江歌母亲江秋莲诉刘鑫案一审将于今日宣判

河南省安阳市两地划为高风险地区 一地划为中风险地区

员工迟到一次罚一千引争议 单位惩戒员工法律边界何在?

以体育人 秀出“青年范儿”

保安、厨师曾被竞业限制 企业滥用竞业限制让员工很苦恼

反诈老陈破圈:人民群众在哪 就把反诈宣传开展到哪

一所中职学校的育人实践

各地严惩恶意欠薪 保障农民工及时拿到工资

中学生成剧本杀行业潜在消费人群 多方助推行业“净化”

“这就是我最好的选择”

对餐饮浪费说“不”(百姓关注)

校园“直通车” 服务“零距离”

琉璃河遗址 两段铭文共证北京三千年建城史

千元修复个人征信报告?银行:“征信修复”都是骗局

琉璃河遗址 两段铭文共证北京三千年建城史

北京公交将开展无人驾驶道路测试

河南郑州调整五地为中风险区域 公路入郑需核酸检测阴性证明

“共享法庭”让金融消费者畅享“智慧司法”便利

《传奇2》网游著作权纠纷案峰回路转 最高法五份裁决四份改判一份发回重审

三代警察:从未放弃的28年

“胡叔叔”的寻亲工作室

天津津南本轮本土疫情第3—20例阳性感染者活动轨迹公布

“团圆”行动刑侦专家吕游 每一个案例都有单独的技术方案

河南“战疫”直面五重考验

开考古书店日均两三个顾客 流量时代她决心仍是只卖书

冬奥开幕在即 “双减”催热冰雪课堂

“不得以任何借口拒收患者”彰显生命至上

天津多站进京车票暂停发售

冷空气来袭广州气温骤降 广东多地发布寒冷预警

x 广告
x 广告

Copyright ©  2015-2022 亚太自然网版权所有  备案号:沪ICP备2020036824号-11   联系邮箱: 562 66 29@qq.com