华为OD机试 - 查找舆情热词(Python/JS/C/C++ 2024 C卷 100分)

在这里插入图片描述

华为OD机试 2024E卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试真题(Python/JS/C/C++)》。

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新。

一、题目描述

网上新闻越来越多,希望对新闻进行热词处理并归类,方便获取信息,现在已经将每篇文章处理为2个字符串,即一个标题,一个正文串,字符串中使用“ ”作为分隔符进行分词。

M篇新闻按照新闻发布的先后顺序处理完并输入,现在希望对所有新闻中出现的词语进行处理,输出出现频率最高的topN个词语,作为热词。标题中出现的词语频率系数为3,正文中出现的词语频率系数为1;返回的答案按照词语出现频率由高到低排序,当词语出现的频率相同时,在标题中出现的频率次数高的排在前面;如果仍然相同,则按照词语在标题中出现的先后顺序进行排序,先出现的排在前面;如果仍然相同,则按照词语在正文中出现的先后顺序进行排序,先出现的排在前面。

二、输入描述

第一行输入为正整数topN和文章数M,即要输出的出现频率最高的词语的个数和处理文章的数量,由于每篇文章被处理为标题和正文2行,因此后面有2 * M行数据。

从第二行起,是按顺序处理后每篇文章的标题串和正文串,即第二行是第一篇文章的标题串,第三行是第一篇文章的正文串,第四行是第二篇文章的标题串,第五行是第二篇文章的正文串,以此类推。

三、输出描述

使用一行输出出现频率最高的topN个词语,每个词语以“ ”隔开。

四、测试用例

测试用例1

1、输入

3 2
xinguan feiyan xinzeng bendi quezhen anli
ju baodao chengdu xinzeng xinguan feiyan bendi quezhen anli yili shenzhen xinzeng bendi quezhen anli liangli yiqing zhhengti kongzhi lianghao
xinguan yimiao linchuang shiyan
wuzhong xinguan yimiao tongguo sanqi linchuang shiyan xiaoguo lianghao

2、输出

xinguan xinzeng bendi

测试用例2

1、输入

3 2
nezha1 nezha2 nezha10 nezha4 nezha5 nezha6
nezha1 nezha2 nezha3 nezha4 nezha4 nezha6 nezha1 nezha2 nezha3 nezha5 nezha6
nezha1 nezha7 nezha8 nezha9 nezha4 nezha10
nezha1 nezha7 nezha8 nezha9 nezha10 nezha11 nezha1 nezha7 nezha8 nezha9 nezha10 nezha11

2、输出

nezha1 nezha10 nezha4

四、解题思路

题目描述就是解题思路:

  1. 标题中出现的词语频率系数为3,正文中出现的词语频率系数为1;
  2. 返回的答案按照词语出现频率由高到低排序
  3. 当词语出现的频率相同时,在标题中出现的频率次数高的排在前面;
  4. 如果仍然相同,则按照词语在标题中出现的先后顺序进行排序,先出现的排在前面;
  5. 如果仍然相同,则按照词语在正文中出现的先后顺序进行排序,先出现的排在前面。

六、Python算法源码

import sys
from collections import defaultdictdef main():# 读取第一行输入first_line = sys.stdin.readline().strip().split()topN = int(first_line[0])M = int(first_line[1])map_freq = defaultdict(int)       # 总词频title_map = defaultdict(int)      # 标题词频content_map = defaultdict(int)    # 正文词频arr_list = []                      # 存储所有标题和正文# 读取每篇文章的标题和正文for i in range(M * 2):line = sys.stdin.readline().strip().split()arr_list.append(line)if i % 2 == 0:  # 标题for word in line:title_map[word] += 3    # 标题词频增加3map_freq[word] += 3      # 总词频增加3else:            # 正文for word in line:content_map[word] += 1    # 正文词频增加1map_freq[word] += 1       # 总词频增加1# 将词频转换为列表以便排序list_freq = list(map_freq.items())# 自定义排序函数def compare(item):word, freq = itemreturn (-freq, -title_map[word], get_first_occurrence(arr_list, word, True), get_first_occurrence(arr_list, word, False))# 获取词语在标题或正文中首次出现的位置def get_first_occurrence(arr_list, word, is_title):start = 0 if is_title else 1step = 2for i in range(start, len(arr_list), step):for w in arr_list[i]:if w == word:return ireturn float('inf')  # 如果未出现,返回无限大# 排序list_freq.sort(key=compare)# 取前topN个词语result = [word for word, freq in list_freq[:topN]]# 输出结果print(' '.join(result))if __name__ == "__main__":main()

七、JavaScript算法源码

const readline = require('readline');function main() {const rl = readline.createInterface({input: process.stdin,output: process.stdout});let input = [];rl.on('line', (line) => {input.push(line.trim());});rl.on('close', () => {let firstLine = input[0].split(' ').map(Number);let topN = firstLine[0];let M = firstLine[1];let mapFreq = new Map();      // 总词频let titleMap = new Map();     // 标题词频let contentMap = new Map();   // 正文词频let arrList = [];             // 存储所有标题和正文for (let i = 0; i < M * 2; i++) {let words = input[1 + i].split(' ');arrList.push(words);if (i % 2 === 0) { // 标题for (let word of words) {titleMap.set(word, (titleMap.get(word) || 0) + 3);mapFreq.set(word, (mapFreq.get(word) || 0) + 3);}} else { // 正文for (let word of words) {contentMap.set(word, (contentMap.get(word) || 0) + 1);mapFreq.set(word, (mapFreq.get(word) || 0) + 1);}}}// 将Map转换为数组let listFreq = Array.from(mapFreq.entries());// 自定义排序listFreq.sort((a, b) => {// 按总频率降序if (b[1] !== a[1]) return b[1] - a[1];// 按标题频率降序let titleA = titleMap.get(a[0]) || 0;let titleB = titleMap.get(b[0]) || 0;if (titleB !== titleA) return titleB - titleA;// 按标题中先出现的顺序let order = getFirstOccurrence(arrList, a[0], true) - getFirstOccurrence(arrList, b[0], true);if (order !== 0) return order;// 按正文中先出现的顺序return getFirstOccurrence(arrList, a[0], false) - getFirstOccurrence(arrList, b[0], false);});// 获取前topN个词语let result = [];for (let i = 0; i < Math.min(topN, listFreq.length); i++) {result.push(listFreq[i][0]);}// 输出结果console.log(result.join(' '));});/*** 获取词语在标题或正文中首次出现的位置* @param {Array} arrList 所有标题和正文* @param {String} word 词语* @param {Boolean} isTitle 是否在标题中查找* @returns {Number} 位置索引*/function getFirstOccurrence(arrList, word, isTitle) {let start = isTitle ? 0 : 1;for (let i = start; i < arrList.length; i += 2) {for (let w of arrList[i]) {if (w === word) return i;}}return Infinity; // 未出现}
}main();

八、C算法源码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define MAX_WORDS 10000
#define MAX_LEN 100typedef struct {char word[MAX_LEN];int total_freq;int title_freq;int first_title;int first_content;
} WordInfo;// 比较函数
int compare(const void *a, const void *b) {WordInfo *w1 = (WordInfo *)a;WordInfo *w2 = (WordInfo *)b;// 按总频率降序if (w2->total_freq != w1->total_freq)return w2->total_freq - w1->total_freq;// 按标题频率降序if (w2->title_freq != w1->title_freq)return w2->title_freq - w1->title_freq;// 按标题中先出现的顺序if (w1->first_title != w2->first_title)return w1->first_title - w2->first_title;// 按正文中先出现的顺序return w1->first_content - w2->first_content;
}int main(){int topN, M;scanf("%d %d", &topN, &M);char buffer[10000][MAX_LEN];int count = 0;WordInfo words[MAX_WORDS];int word_count = 0;for(int i = 0; i < M * 2; i++){scanf(" %[^\n]", buffer[i]);char *token = strtok(buffer[i], " ");while(token != NULL){// 查找是否已存在int found = -1;for(int j = 0; j < word_count; j++){if(strcmp(words[j].word, token) == 0){found = j;break;}}if(found == -1){strcpy(words[word_count].word, token);words[word_count].total_freq = 0;words[word_count].title_freq = 0;words[word_count].first_title = -1;words[word_count].first_content = -1;found = word_count;word_count++;}// 更新频率if(i % 2 == 0){ // 标题words[found].total_freq += 3;words[found].title_freq += 3;if(words[found].first_title == -1){words[found].first_title = i /2;}}else{ // 正文words[found].total_freq +=1;if(words[found].first_content == -1){words[found].first_content = i /2;}}token = strtok(NULL, " ");}}// 排序qsort(words, word_count, sizeof(WordInfo), compare);// 输出前topN个词语for(int i = 0; i < topN && i < word_count; i++){printf("%s ", words[i].word);}printf("\n");return 0;
}

九、C++算法源码

#include <bits/stdc++.h>
using namespace std;struct WordInfo {string word;int total_freq;int title_freq;int first_title;int first_content;
};int main(){int topN, M;cin >> topN >> M;cin.ignore(); // 忽略换行符vector<vector<string>> arrList;unordered_map<string, WordInfo> wordMap;int word_count = 0;for(int i = 0; i < M *2; i++){string line;getline(cin, line);vector<string> words;string word;stringstream ss(line);while(ss >> word){words.push_back(word);if(wordMap.find(word) == wordMap.end()){WordInfo wi;wi.word = word;wi.total_freq = 0;wi.title_freq = 0;wi.first_title = -1;wi.first_content = -1;wordMap[word] = wi;}if(i %2 ==0){ // 标题wordMap[word].total_freq +=3;wordMap[word].title_freq +=3;if(wordMap[word].first_title == -1){wordMap[word].first_title = arrList.size();}}else{ // 正文wordMap[word].total_freq +=1;if(wordMap[word].first_content == -1){wordMap[word].first_content = arrList.size();}}}arrList.push_back(words);}// 转换为vectorvector<WordInfo> words;for(auto &p: wordMap){words.push_back(p.second);}// 排序sort(words.begin(), words.end(), [&](const WordInfo &a, const WordInfo &b) -> bool{if(a.total_freq != b.total_freq)return a.total_freq > b.total_freq;if(a.title_freq != b.title_freq)return a.title_freq > b.title_freq;if(a.first_title != b.first_title)return a.first_title < b.first_title;return a.first_content < b.first_content;});// 输出前topN个词语for(int i =0; i < topN && i < words.size(); i++){cout << words[i].word;if(i != topN-1 && i != words.size()-1){cout << " ";}}cout << endl;return 0;
}

🏆下一篇:华为OD机试真题 - 简易内存池(Python/JS/C/C++ 2024 E卷 200分)

🏆本文收录于,华为OD机试真题(Python/JS/C/C++)

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/12857.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

从容应对蓝屏:必知原因与对策

电脑蓝屏&#xff0c;即“蓝屏死机”或“蓝屏错误”&#xff0c;是计算机用户在日常使用中可能遇到的一种较为严重的系统错误状态。当屏幕突然变成蓝色&#xff0c;并显示错误代码和信息时&#xff0c;这通常意味着系统遇到了无法处理的问题&#xff0c;了解电脑蓝屏的原因及解…

每日小练:Day1

1.牛牛冲钻五 题目链接&#xff1a;A-牛牛冲钻五_牛客小白月赛38 题目描述&#xff1a; 代码如下&#xff1a; import java.util.*;public class Main{public static void main(String[] args){Scanner scannernew Scanner(System.in);int tscanner.nextInt();while(t--!0){…

springboot汽车租赁智慧管理-计算机设计毕业源码96317

目 录 第 1 章 引 言 1.1 选题背景 1.2 研究现状 1.3 论文结构安排 第 2 章 系统的需求分析 2.1 系统可行性分析 2.1.1 技术方面可行性分析 2.1.2 经济方面可行性分析 2.1.3 法律方面可行性分析 2.1.4 操作方面可行性分析 2.2 系统功能需求分析 2.3 系统性需求分析…

从社交媒体到元宇宙:Facebook未来发展新方向

Facebook&#xff0c;作为全球最大的社交媒体平台之一&#xff0c;已经从最初的简单互动工具发展成为一个跨越多个领域的科技巨头。无论是连接人与人之间的社交纽带&#xff0c;还是利用大数据、人工智能等技术为用户提供个性化的体验&#xff0c;Facebook一直引领着社交网络的…

用Python比较对象,你还在用==?

包含编程资料、学习路线图、源代码、软件安装包等&#xff01;【[点击这里]】&#xff01; 1.基础比较&#xff1a; 和 is 在Python中&#xff0c;对象间的比较是程序设计中的基础且重要的一环&#xff0c;它直接关系到数据处理的逻辑和效率。本章将深入探讨两种基本的比较操…

MySQL 中的集群部署方案

文章目录 MySQL 中的集群部署方案MySQL ReplicationMySQL Group ReplicationInnoDB ClusterInnoDB ClusterSetInnoDB ReplicaSetMMMMHAGalera ClusterMySQL ClusterMySQL Fabric 总结参考 MySQL 中的集群部署方案 MySQL Replication MySQL Replication 是官方提供的主从同步方…

Vision Pro空间叙事创作工具:开启多媒体融合新纪元

在数字内容创作领域迎来了一位新玩家——专为Apple Vision Pro设计的空间叙事创作工具。这款工具不仅是一个沉浸式内容分享平台&#xff0c;更是面向空间计算时代的内容创作解决方案&#xff0c;它旨在通过全新的多媒体融合方式&#xff0c;打破传统内容创作的界限。 产品优势…

屏幕水印是什么,怎么设置丨超级简单的防盗水印教程来了,包教包会!

小李&#xff1a;现在科技这么发达&#xff0c;随便一截图或者拍照&#xff0c;信息就满天飞了 小张&#xff1a;给你的电脑屏幕安排一件“隐形战衣”呗 小李&#xff1a;哦&#xff1f;新词儿&#xff1f;些许陌生 小张&#xff1a;简而言之&#xff0c;言而简之&#xff0…

css:没错又是我

背景 给元素添加背景样式 还可以设置背景颜色、背景图片&#xff08;教练我要学这个&#xff09;、背景平铺、背景图片位置、背景图像固定 背景颜色 这个我们用过&#xff0c;就是&#xff1a; a {background-color: hotpink; } 一般默认值是transparent&#xff0c;也就…

adb 如何通过wifi连接手机

1. 电脑通过USB线连接手机 1.1手机开启开发者模式 以小米手机为例&#xff1a;连续点击OS版本系统&#xff08;设置–>我的设备–>全部参数&#xff09; 1.2在开发者模式下&#xff0c;启动允许USB安装与USB调试 操作步骤&#xff1a;设置>更多设置>开发者选项&g…

自己开发得期货资管模拟软件演示1.0.15版仅供学习

期货资管模拟软件演示1.0.15版仅供学习——C技术栈知识分享 本文将以期货资管模拟软件演示1.0.15版为例&#xff0c;分享其基于C技术栈的框架知识。 一、C技术栈在期货交易软件开发中的应用 C作为一种高性能的编程语言&#xff0c;以其强大的内存管理能力和高效的执行速度&a…

浅谈单片机的gcc优化级别__以双音频信号发生器为例

IDE&#xff1a; CLion HOST&#xff1a; Windows 11 MinGW&#xff1a;x86_64-14.2.0-release-posix-seh-ucrt-rt_v12-rev0 GCC&#xff1a; arm-gnu-toolchain-13.3.rel1-mingw-w64-i686-arm-none-eabi 一、简介 gcc有多种优化级别&#xff0c;一般不选择的情况下&#x…

C++之继承多态

C之继承&多态 继承继承之形继承的作用域继承的构造与析构多继承菱形继承 多态多态之形final和override(C11)纯虚函数&抽象类多态的原理打印虚表&#xff08;在vs2022中&#xff09;多继承下的虚表菱形虚继承中埋的坑静态多态与动态多态我对虚函数和普通成员函数调用区别…

机器学习-36-对ML的思考之机器学习研究的初衷及科学研究的期望

文章目录 1 机器学习最初的样子1.1 知识工程诞生(专家系统)1.2 知识工程高潮期1.3 专家系统的瓶颈(知识获取)1.4 机器学习研究的初衷2 科学研究对机器学习的期望2.1 面向科学研究的机器学习轮廓2.2 机器学习及其应用研讨会2.3 智能信息处理系列研讨会2.4 机器学习对科学研究的重…

arm 汇编技巧

汇编标号&#xff1a;f表示forward&#xff0c; b表示backward&#xff1a; Here is an example: 1: branch 1f 2: branch 1b 1: branch 2f 2: branch 1b Which is the equivalent of: label_1: branch label_3 label_2: branch label_1 label_3: branch label_4 label_4: bra…

特色3D打印stm32迷你8轴双核心主板

我自己设计的3D打印机主板 1. 这是一块迷你的8轴主板, 主板尺寸为100mm*75mm, 使用一个8cm静音风扇散热足够了2. 这是一个带有保护的板子, 驱动上的gpio具有过压保护功能, 能够直接抗住24V的冲击, 意味着一个驱动炸了, 板子不烧, 并且其他的驱动也没事, 主板支持自动关机3. 8…

golang分布式缓存项目 Day2 单机并发缓存

注&#xff1a;该项目原作者&#xff1a;https://geektutu.com/post/geecache-day1.html。本文旨在记录本人做该项目时的一些疑惑解答以及部分的测试样例以便于本人复习。 支持并发读写 接下来我们使用 sync.Mutex 封装 LRU 的几个方法&#xff0c;使之支持并发的读写。在这之…

2024 年将 Swagger 导入 Postman 图文教程

2024 年将 Swagger 导入 Postman 图文教程

从入门到精通:hello-algo开源项目助你系统学习数据结构与算法

文章目录 前言1.关于hello-algo2.安装Docker和Docker compose3.本地部署hello-algo4. hello-algo本地访问5.cpolar内网穿透工具安装6.创建远程连接公网地址7.固定Uptime Kuma公网地址 前言 本文将探讨如何在本地环境中部署hello-algo这一算法学习必备项目&#xff0c;并利用cp…

SystemVerilog学习笔记(七):函数与任务

函数 函数的主要用途是编写一段可以随时调用n次的代码&#xff0c;只需调用函数名即可&#xff0c;不需要任何模拟时间来执行。函数是返回类型&#xff0c;仅返回函数声明中提到的单个值&#xff0c;如果未声明则返回一个位的值。 语法&#xff1a; initial begin functio…