C语言 | Leetcode C语言题解之第290题单词规律

题目:

题解:

typedef struct node_t
{char *key;char *value;struct node_t* pnext;
}NODE_T;typedef struct hash_t
{NODE_T** hash_list;int size;
}HASH_T;HASH_T *hash_init(int size)
{HASH_T *hash = (HASH_T *)malloc(sizeof(HASH_T));if(NULL == hash){printf("open space error!");exit(0);}hash->hash_list = NULL;hash->size = size;hash->hash_list = (NODE_T **)calloc(size, sizeof(NODE_T *));if(NULL == hash->hash_list){printf("open space error!");exit(0);}for(int i = 0; i < size; i++){hash->hash_list[i] = (NODE_T *)calloc(size, sizeof(NODE_T));if(NULL == hash->hash_list[i]){printf("open space error!");exit(0);}}return hash;
}int hash_pos(HASH_T *hash, char *key) // 返回当前键值所在链表
{return key[0] % hash->size;
}NODE_T* hash_find(HASH_T *hash, char *key) // 返回值在链表的节点
{int pos = hash_pos(hash, key);NODE_T *now_node = hash->hash_list[pos]->pnext;while(now_node != NULL && strcmp(now_node->key, key)){now_node = now_node->pnext;}return now_node;
}bool hash_put(HASH_T *hash, char *key, char *value) // 比对键值信息,未找到新建节点存储键值
{NODE_T *now_node = hash_find(hash, key);NODE_T *new_node = NULL;if(NULL == now_node){new_node = (NODE_T*)malloc(sizeof(NODE_T));if(NULL == new_node){printf("open space error!");exit(0);}new_node->key = (char*)malloc(sizeof(char) * (strlen(key) + 1));if(NULL == new_node->key){printf("open space error!");exit(0);}strcpy(new_node->key, key);new_node->value = (char*)malloc(sizeof(char) * (strlen(value) + 1));if(NULL == new_node->value){printf("open space error!");exit(0);}strcpy(new_node->value, value);new_node->pnext = hash->hash_list[hash_pos(hash, key)]->pnext;hash->hash_list[hash_pos(hash, key)]->pnext = new_node;}else{if(0 != strcmp(now_node->value, value)){return false;}}return true;
}bool wordPattern(char* s, char* pattern) {HASH_T *pattern_hash = hash_init(26);HASH_T *s_hash = hash_init(26);char *str_pattern = NULL, *str_s = NULL; // 用于存放值int *pattern_count = NULL; // 存放每个单词所处下标int i = 0, count = 0, pattern_len = strlen(pattern), s_len = strlen(s); // 用于轮询数组,数组长度str_pattern = (char *)calloc(pattern_len + 1, sizeof(char)); // 分配值空间if(NULL == str_pattern){printf("open space error!");exit(0);}str_s = (char *)calloc(2, sizeof(char));if(NULL == str_s){printf("open space error!");exit(0);}pattern_count = (int *)calloc(pattern_len, sizeof(int));if(NULL == pattern_count){printf("open space error!");exit(0);}pattern_count[count++] = 0; // 添加第一个下标for(i = 0; i < pattern_len; i++) // 替换空格,用于strcpy来拷贝单词{if(' ' == pattern[i]){pattern_count[count++] = i + 1; // 下一个单词起始位置pattern[i] = '\0';}}if(s_len != count) // 单词数不一致退出{return false;}for(i = 0; i < s_len; i++){strcpy(str_pattern, &pattern[pattern_count[i]]); // 放入当前比对值str_s[0] = s[i];if(!hash_put(pattern_hash, str_pattern, str_s) || !hash_put(s_hash, str_s, str_pattern)){return false;}}return true;
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

搭建本地私有知识问答系统:MaxKB + Ollama + Llama3 (wsl网络代理配置、MaxKB-API访问配置)

目录 搭建本地私有知识问答系统:MaxKB、Ollama 和 Llama3 实现指南引言MaxKB+Ollama+Llama 3 Start buildingMaxKB 简介:1.1、docker部署 MaxKB(方法一)1.1.1、启用wls或是开启Hyper使用 WSL 2 的优势1.1.2、安装docker1.1.3、docker部署 MaxKB (Max Knowledge Base)MaxKB …

近期代码报错解决笔记

1.TypeError: ‘bool’ object is not callable 想print("Type of head:", type(entity_emb[head]))&#xff0c;结果报如下错误&#xff1a; 源代码&#xff1a; 因为 print 仍然被当作一个布尔值处理&#xff0c;而不是作为函数调用。这个问题的根源在于 print …

将YOLOv8模型从PyTorch的.pt格式转换为TensorRT的.engine格式

TensorRT是由NVIDIA开发的一款高级软件开发套件(SDK)&#xff0c;专为高速深度学习推理而设计。它非常适合目标检测等实时应用。该工具包可针对NVIDIA GPU优化深度学习模型&#xff0c;从而实现更快、更高效的运行。TensorRT模型经过TensorRT优化&#xff0c;包括层融合(layer …

2024最新版虚拟便携空调小程序源码 支持流量主切换空调型号

产品截图 部分源代码展示 urls.js Object.defineProperty(exports, "__esModule", {value: !0 }), exports.default ["9c5f1fa582bee88300ffb7e28dce8b68_3188_128_128.png", "E-116154b04e91de689fb1c4ae99266dff_960.svg", "573eee719…

Sqli-labs-master的21—25通关教程

目录 Less-21(闭合) 查询数据库名 查询数据库中的表 查询表中字段名 查询表中数据 Less-22&#xff08;"闭合&#xff09; 查询数据库名 查询数据库中的表 查询表中字段名 查询表中数据 Less-23 查询数据库名 查询数据库中的表 查询表中字段名 查询表中数据…

Docker核心技术:Docker的基本使用

云原生学习路线导航页&#xff08;持续更新中&#xff09; 本文是 Docker核心技术 系列文章&#xff1a;Docker的基本使用&#xff0c;其他文章快捷链接如下&#xff1a; 应用架构演进容器技术要解决哪些问题Docker的基本使用&#xff08;本文&#xff09;Docker是如何实现的 3…

14.死信队列

介绍 死信就是无法被消费的消息。生产者将消息投递给broker或者直接到队列里&#xff0c;消费者从队列中取出消息进行消费。但是某些时候由于特定的原因导致queue中的某些消息无法被消费&#xff0c;这样的消息如果没有后续处理&#xff0c;就变成了死信。有死信自然就有死信队…

【C++跬步积累】—— list模拟实现(含源代码,超详细)

&#x1f30f;博客主页&#xff1a;PH_modest的博客主页 &#x1f6a9;当前专栏&#xff1a;C跬步积累 &#x1f48c;其他专栏&#xff1a; &#x1f534; 每日一题 &#x1f7e1; Linux跬步积累 &#x1f7e2; C语言跬步积累 &#x1f308;座右铭&#xff1a;广积粮&#xff0…

【AIGC】构建自己的谷歌搜索引擎服务并使用

一、谷歌 谷歌的搜索引擎需要自己创建服务才能启用检索api。&#xff08;需自行翻墙和创建自己的谷歌账号&#xff09; 1.1 API服务创建 1&#xff09;登陆https://console.cloud.google.com/: 2&#xff09; 选择新建项目&#xff0c;取号项目名即可&#xff08;比如:Olin…

arinc664总线协议

AFDX总线协议简介 &#xff08;1&#xff09;AFDX的传输速率高&#xff1a;带宽100MHZ&#xff0c;远远高于其他的类型的航空总线。&#xff08;2&#xff09;AFDX网络的鲁棒性高&#xff1a;AFDX的双冗余备份网络可以在某一个网络出现故障时&#xff0c;仍能正常通讯。 其中…

IP数据报结构详解:从基础到进阶

目录 IP数据报的格式 IP数据报首部的固定部分 IP数据报首部的可变部分 实例分析&#xff1a;数据报的分片 生存时间&#xff08;TTL&#xff09;与协议 首部检验和 总结 在网络通信中&#xff0c;IP数据报是至关重要的基本单元。本文将带您深入了解IP数据报的格式及其各个…

聚焦保险行业客户经营现状,概述神策数据 CJO 解决方案

触点红利时代&#xff0c;企业的经营需求从「深度的用户行为分析」转变为「个性化、全渠道一致的客户体验」。客户旅程编排&#xff08;Customer Journey Orchestration&#xff0c;简称 CJO&#xff09;从体验出发&#xff0c;关注客户需求、感受和满意度&#xff0c;能够帮助…

JavaWeb笔记_JSTL标签库JavaEE三层架构案例

一.JSTL标签库 1.1 JSTL概述 JSTL(jsp standard tag library):JSP标准标签库,它是针对EL表达式一个扩展,通过JSTL标签库与EL表达式结合可以完成更强大的功能 JSTL它是一种标签语言,JSTL不是JSP内置标签 JSTL标签库主要包含: ****核心标签 格式化标签 …

Windows本地启动Redis

找到本地redis目录 输入cmd,然后输入redis-server.exe redis.windows.conf&#xff0c;默认端口为6379 再新打开一个cmd&#xff0c;输入redis-cli.exe -p 6379 -a &#xff08;你在redis.windows.conf中设置的密码&#xff09;

.NET程序集编辑器/调试器 dnSpy 使用介绍

原文链接&#xff1a;https://www.cnblogs.com/zhaotianff/p/17352882.html dnSpy dnSpy是一个.NET程序集调试器和编辑器。它可以用它来编辑和调试程序集&#xff0c;即使在没有源码的情况下。 主要功能&#xff1a; 调试.NET和Unity程序集 编辑.NET和Unity程序集 项目地…

25.x86游戏实战-理解发包流程

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 本次游戏没法给 内容参考于&#xff1a;微尘网络安全 工具下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd6tw3 提…

IOS微软语音转文本,lame压缩音频

在IOS开发中&#xff0c;用微软进行语音转文本操作&#xff0c;并将录音文件压缩后返回 项目中遇到了利用微软SDK进行实时录音转文本操作&#xff0c;如果操作失败&#xff0c;那么就利用原始音频文件通过网络请求操作&#xff0c;最终这份文件上传到阿里云保存&#xff0c;考…

Golang学习笔记20240725,Go语言基础语法

第一个Go程序 package mainimport "fmt"func main() {fmt.Println("hello world") }运行方式1&#xff1a; go run main.go运行方式2&#xff1a; go build .\hello_go.exe运行方式3&#xff1a;goland右键运行 字符串拼接 使用加号可以对字符串进行…

基于微信小程序的校园警务系统/校园安全管理系统/校园出入管理系统

摘要 伴随着社会以及科学技术的发展&#xff0c;小程序已经渗透在人们的身边&#xff0c;小程序慢慢的变成了人们的生活必不可少的一部分&#xff0c;紧接着网络飞速的发展&#xff0c;小程序这一名词已不陌生&#xff0c;越来越多的学校机构等都会定制一款属于自己个性化的小程…

UML通信图建模技术及应用例

新书速览|《UML 2.5基础、建模与设计实践》 在对系统的动态行为进行建模时&#xff0c;通信图常被用于按组织结构对控制流进行建模。与顺序图一样&#xff0c;一个单独的通信图只能显示一个控制流。 使用通信图建模时可以遵循如下策略&#xff1a; &#xff08;1&#xff09…