华为od机试 - 找出两个整数数组中同时出现的整数( C++ Java JavaScript )

这篇博客介绍了华为OD统一考试B卷的一道题目,要求找出两个整数数组中同时出现的整数,并按照出现次数排序输出。博客提供了C++、Python、Java和JavaScript的代码示例,以及多个测试用例。此外,还强调了机考中的代码查重问题,建议考生在遇到原题时修改变量名和代码结构。

题目描述:找出两个整数数组中同时出现的整数

现有两个整数数组,需要你找出两个数组中同时出现的整数,并按照如下要求输出:

1、有同时出现的整数时,先按照同时出现次数(整数在两个数组中都出现并且出现次数较少的那个)进行归类,然后按照出现次数从小到大依次按行输出。

2、没有同时出现的整数时,输出NULL。

输入描述:

第一行为第一个整数数组,第二行为第二个整数数组,每行数据中整数与整数之间以英文逗号分隔,整数的取值范围为[-200,200],数组长度的范围为[1,10000]之间的整数。

输出描述:

按照出现次数从小到大依次按行输出,每行输出的格式为:出现次数:该出现次数下的整数升序排序的结果。

格式中的":"为英文冒号,整数间以英文逗号分隔。

ACM输入输出模式

如果你经常使用Leetcode,会知道letcode是不需要编写输入输出函数的。但是华为OD机考使用的是 ACM 模式,需要手动编写输入和输出。

所以最好在牛-客上提前熟悉这种模式。例如C++使用cin/cout,python使用input()/print()。JavaScript使用node的readline()console.log()。Java 使用sacnner/system.out.print()

用例1

输入:

5,3,6,-8,0,11
2,8,8,8,-1,15

输出:

NULL

说明:

两个整数数组没有同时出现的整数,输出NULL。

用例2

输入:

5,8,11,3,6,8,8,-1,11,2,11,11
11,2,11,8,6,8,8,-1,8,15,3,-9,11

输出:

1:-1,2,3,6
3:8,11

说明:

两个整数数组中同时出现的整数为-1、2、3、6、8、11,其中同时出现次数为1的整数为-1,2,3,6(升序排序),同时出现次数为3的整数为8,11(升序排序),先升序输出出现次数为1的整数,再升序输出出现次数为3的整数。

机考代码查重

华为OD机考完成之后,官方会进行代码查重。华为 od 机考确实有很大的概率抽到原题。如果碰到了题库中的原题,一定不要直接使用题解中的代码,尤其是变量名,一定要修改,可以改成毫无意义的单词。除了变量名之外,代码的组织结构和逻辑一定要进行改变,这就要求在日常的刷题中,提前编写好属于自己的代码。

C++

#include <iostream>
#include <sstream>
### 数字涂色问题概述 数字涂色问题是华为OD中的一类经典算法题目,主要考察考生的编程能力和对复杂问题的解决能力。该问题不仅涉及基本的数据结构和算法应用,还需要考虑时间效率以及空间优化等问题[^1]。 以下是针对此问题的具体分析与解决方案: --- #### 问题描述 给定一组连续区间 `[a, b]` 和若干颜色编号 `c`,要求将这些区间的整数按照指定的颜色进行标记。最终统计每种颜色覆盖了多少个不同的整数点,返回结果列表。需要注意的是,某些区域可能会被多次重复涂色,因此需要去重计算每个颜色的实际覆盖范围[^3]。 --- #### 解决方案 为了高效完成这一任务,可以采用如下方法: 1. **离散化处理**:通过记录所有可能的关键点来减少不必要的遍历操作; 2. **差分数组技术**:利用差分数组快速求解区间叠加效果; 3. **哈希表辅助计数**:借助集合或者映射存储已访问过的节点及其对应属性。 下面分别给出 C++JavaJavaScriptPython 的具体实现版本附带相应解释说明。 --- ##### 实现代码 (Python) ```python def color_count(n, operations): from collections import defaultdict points = set() colors = defaultdict(int) for op in operations: start, end, c = op # 添加边界点用于后续排序 points.update(range(start, end + 1)) sorted_points = sorted(points) point_map = {v: i for i, v in enumerate(sorted_points)} diff_array = [0] * len(point_map) for s, e, col in operations: if s in point_map and e in point_map: diff_array[point_map[s]] += 1 if e + 1 < len(sorted_points): diff_array[point_map[e]+1] -= 1 current_color = 0 prev_index = None active_colors = set() result = {} for idx, val in enumerate(diff_array): current_color += val if current_color > 0: active_colors.add(col) # 假设col为当前活跃颜色 if prev_index is not None: length = sorted_points[idx]-sorted_points[prev_index] for ac in list(active_colors): if ac != 0: result[ac] = result.get(ac, 0)+length prev_index = idx res_list = [] for k in range(1,n+1): res_list.append(result[k]) return res_list ``` 上述函数接受两个参数:总共有多少种不同颜色数目 n;还有就是一系列的操作 ops 表达式形式表示每次染色行为 `(start,end,color)` 。最后它会输出一个长度等于n的结果向量其中第i项代表颜色i所占据的位置数量[^1]。 --- ##### 实现代码 (C++) ```cpp #include <bits/stdc++.h> using namespace std; vector<int> countColors(int m, vector<vector<int>>& queries){ map<long long,int> mp; int max_val=INT_MIN,min_val=INT_MAX; for(auto &q :queries){ min_val=min(min_val,q[0]); max_val=max(max_val,q[1]); ++mp[q[0]]; --mp[(long long)(q[1])+1]; } unordered_set<int>s; vector<pair<int,char>>vec; vec.reserve(mp.size()); for(auto &[k,v]:mp){vec.emplace_back(k,'s');} sort(vec.begin(),vec.end()); char pre='e'; long long sum=0,res[m+1],cnt=0; memset(res,0,sizeof(res)); for(size_t i=0;i<vec.size();i++){ auto &[pos,ch]=vec[i]; if(pre=='s'&&ch=='s'){ cnt++; continue; }else{ if(s.empty())continue; res[*s.begin()]+= pos-(pre=='s'?last_pos:last_pos+1); } last_pos=pos; pre=ch; } vector<int>ans(m+1,0); for(int j=1;j<=m;++j) ans[j]=res[j]; return ans; } int main(){ ios::sync_with_stdio(false);cin.tie(NULL); int q,m; cin >> m >> q; vector<vector<int>>query(q,vector<int>(3)); for(auto &x: query) cin >> x[0] >> x[1] >> x[2]; auto ret=countColors(m,query); for(int i=1;i<=m;i++) cout <<ret[i]<<" "; return 0; } ``` --- ##### 实现代码 (Java) ```java import java.util.*; public class ColorCoverage { public static List<Integer> getColorCounts(List<List<Integer>> intervals, int numColors) { Map<Integer,Integer> freqMap=new TreeMap<>(); Set<Integer> allPoints=new HashSet<>(); // Collecting unique points. for(var interval:intervals){ allPoints.addAll(IntStream.rangeClosed(interval.get(0),interval.get(1)).boxed().toList()); } var sortedList=allPoints.stream().sorted().collect(Collectors.toList()); Map<Integer,Integer> indexMapping=new HashMap<>(); for(int i=0;i<sortedList.size();i++)indexMapping.put(sortedList.get(i),i); int[] diffs=new int[indexMapping.size()+2]; for(var interval:intervals){ Integer l=indexMapping.getOrDefault(interval.get(0),null); Integer r=indexMapping.getOrDefault(interval.get(1),null); if(l!=null && r!=null){ diffs[l]++; diffs[r+1]--; } } List<Integer> results=new ArrayList<>(Collections.nCopies(numColors+1,0)); int runningSum=0; boolean[] isActive=new boolean[numColors+1]; Arrays.fill(isActive,false); for(int i=0;i<diffs.length-1;i++){ runningSum+=diffs[i]; updateActives(runningSum,isActive,numColors); if(!isActive[intervals.get(i).get(2)])continue; int dist=Math.abs(sortedList.get(i)-sortedList.get(i-1))+1; synchronized(results){ results.set(intervals.get(i).get(2), results.get(intervals.get(i).get(2))+(dist*(runningSum))); } } return results.subList(1,results.size()-1); } private static void updateActives(int rs,bool[] actvs,int nc){ for(int ci=1;ci<=nc;ci++)actvs[ci]=(rs&Math.pow(2,(ci-1)))>0?true:false; } } ``` --- #### 注意事项 尽管提供了多种语言的标准解答模板,但在实际参加考时应特别注意以下几点: - 修改变量命名习惯以降低与其他参赛者提交内容相似度的风险。 - 调整程序框架结构从而体现个人风格差异性。 -更多极端情况下的表现验证鲁棒性和正确率[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值