希哈表的学习
#include <stdio.h>
#include <stdlib.h>
#include "uthash.h"typedef struct {int id; // 学号,作为keychar name[20]; // 姓名,作为valueUT_hash_handle hh; // 必须有这个字段
} Student;Student* students = NULL; // 哈希表的头指针(初始为NULL)int main() {Student* s1 = (Student*)malloc(sizeof(Student));Student* s2 = (Student*)malloc(sizeof(Student));s1->id = 1001;s2->id = 1002;strcpy(s1->name, "张三");strcpy(s2->name, "李四");// 把s1加入哈希表,按id做keyHASH_ADD_INT(students, id, s2); //HASH_ADD_INT(哈希表名, 键字段名, 条目指针);HASH_ADD_INT(students, id, s1);// 查找学号的学生Student* find = NULL;int search_id = 1001;HASH_FIND_INT(students, &search_id, find); //HASH_FIND_INT(哈希表名, 键字段值的地址, 找到的条目指针);if (find) {printf("找到了:%s\n", find->name);}else {printf("没找到\n");}// 释放内存HASH_DEL(students, s1); //HASH_DEL() 的作用就是:从哈希表中删除一个指定的结构体(条目)。HASH_DEL(哈希表名, 条目指针);free(s1);return 0;
}

HASH_ADD_INT(哈希表头指针, key字段名, 结构体指针);

HASH_FIND_INT(哈希表名, key指针, 输出结果指针);


HASH_DEL(哈希表头指针, 要删除的结构体指针);


HASH_ITER(hh, head, elt, tmp)


例题
统计数组中每个元素出现的次数

#include <stdio.h>
#include "uthash.h"
#include <stdlib.h>typedef struct
{int Key; //数字int count; //出现次数UT_hash_handle hh; //哈希句柄
}HashEntry;int main()
{int nums[] = {1, 2, 3, 2, 1, 1};int n = sizeof(nums) / sizeof(nums[0]);HashEntry*hashTable = NULL;for (int i = 0; i < n; i++){int num = nums[i];HashEntry*entry;HASH_FIND_INT(hashTable, &num, entry);if(entry){entry->count += 1;}else{entry = (HashEntry*)malloc(sizeof(HashEntry));entry->Key = num;entry->count = 1;HASH_ADD_INT(hashTable, Key, entry);}}HashEntry*e, *tmp;HASH_ITER(hh, hashTable, e, tmp){printf("%d: %d次\n", e->Key, e->count);}HASH_ITER(hh, hashTable, e, tmp){HASH_DEL(hashTable, e);free(e);}
}

数组中第一个只出现一次的元素

#include <stdio.h>
#include "uthash.h"
#include <stdlib.h>// 定义哈希表结构
typedef struct {int key; // 数字int count; // 出现次数UT_hash_handle hh; // 哈希句柄
} HashEntry;int findFirstUnique(int* nums, int n) {HashEntry *hashTable = NULL;// 第一次遍历:统计每个数字出现次数for (int i = 0; i < n; i++) {int num = nums[i];HashEntry *entry;HASH_FIND_INT(hashTable, &num, entry);if (entry) {entry->count += 1;} else {entry = (HashEntry*)malloc(sizeof(HashEntry));entry->key = num;entry->count = 1;HASH_ADD_INT(hashTable, key, entry);}}// 第二次遍历:找出第一个只出现一次的数字int result = -1;for (int i = 0; i < n; i++) {HashEntry *entry;HASH_FIND_INT(hashTable, &nums[i], entry);if (entry && entry->count == 1) {result = nums[i];break;}}// 清理哈希表HashEntry *e, *tmp;HASH_ITER(hh, hashTable, e, tmp) {HASH_DEL(hashTable, e);free(e);}return result;
}int main() {int nums[] = {4, 5, 1, 2, 1, 2, 0};int n = sizeof(nums) / sizeof(nums[0]);int result = findFirstUnique(nums, n);if (result != -1) {printf("第一个只出现一次的元素是:%d\n", result);} else {printf("没有只出现一次的元素\n");}return 0;
}
判断数组中是否存在重复元素


#include <stdio.h>
#include <stdlib.h>
#include "uthash.h"// 定义哈希结构
typedef struct {int key; // 数组元素值UT_hash_handle hh; // 哈希句柄
} HashEntry;int containsDuplicate(int* nums, int numsSize) {HashEntry *hashTable = NULL;for (int i = 0; i < numsSize; i++) {int num = nums[i];HashEntry *entry;HASH_FIND_INT(hashTable, &num, entry);if (entry) {// 找到了,说明重复// 清理哈希表HashEntry *e, *tmp;HASH_ITER(hh, hashTable, e, tmp) {HASH_DEL(hashTable, e);free(e);}return 1; // true} else {// 没找到,加入哈希表entry = (HashEntry*)malloc(sizeof(HashEntry));entry->key = num;HASH_ADD_INT(hashTable, key, entry);}}// 清理哈希表HashEntry *e, *tmp;HASH_ITER(hh, hashTable, e, tmp) {HASH_DEL(hashTable, e);free(e);}return 0; // false
}int main() {int nums1[] = {1, 2, 3, 4}; // 无重复int nums2[] = {1, 2, 3, 2}; // 有重复printf("nums1 是否有重复:%s\n", containsDuplicate(nums1, 4) ? "是" : "否");printf("nums2 是否有重复:%s\n", containsDuplicate(nums2, 4) ? "是" : "否");return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include "uthash.h"// 定义哈希结构
typedef struct {int key; // 数组元素值UT_hash_handle hh; // 哈希句柄
} HashEntry;int containsDuplicate(int* nums, int numsSize) {HashEntry *hashTable = NULL;for (int i = 0; i < numsSize; i++) {int num = nums[i];HashEntry *entry;HASH_FIND_INT(hashTable, &num, entry);if (entry) {// 找到了,说明重复// 清理哈希表HashEntry *e, *tmp;HASH_ITER(hh, hashTable, e, tmp) {HASH_DEL(hashTable, e);free(e);}return 1; // true} else {// 没找到,加入哈希表entry = (HashEntry*)malloc(sizeof(HashEntry));entry->key = num;HASH_ADD_INT(hashTable, key, entry);}}// 清理哈希表HashEntry *e, *tmp;HASH_ITER(hh, hashTable, e, tmp) {HASH_DEL(hashTable, e);free(e);}return 0; // false
}int main() {int nums1[] = {1, 2, 3, 4}; // 无重复int nums2[] = {1, 2, 3, 2}; // 有重复printf("nums1 是否有重复:%s\n", containsDuplicate(nums1, 4) ? "是" : "否");printf("nums2 是否有重复:%s\n", containsDuplicate(nums2, 4) ? "是" : "否");return 0;
}
相关文章:
希哈表的学习
#include <stdio.h> #include <stdlib.h> #include "uthash.h"typedef struct {int id; // 学号,作为keychar name[20]; // 姓名,作为valueUT_hash_handle hh; // 必须有这个字段 } Student;Student* studen…...
Qt之OpenGL使用Qt封装好的着色器和编译器
代码 #include "sunopengl.h"sunOpengl::sunOpengl(QWidget *parent) {}unsigned int VBO,VAO; float vertices[]{0.5f,0.5f,0.0f,0.5f,-0.5f,0.0f,-0.5f,-0.5f,0.0f,-0.5f,0.5f,0.0f };unsigned int indices[]{0,1,3,1,2,3, }; unsigned int EBO; sunOpengl::~sunO…...
备赛蓝桥杯-Python-考前突击
额,,离蓝桥杯开赛还有十个小时,最近因为考研复习节奏的问题,把蓝桥杯的优先级后置了,突然才想起来还有一个蓝桥杯呢。。 到目前为止python基本语法熟练了,再补充一些常用函数供明天考前再背背,算…...
零基础开始学习鸿蒙开发-智能家居APP离线版介绍
目录 1.我的小屋 2.查找设备 3.个人主页 前言 好久不发博文了,最近都忙于面试,忙于找工作,这段时间终于找到工作了。我对鸿蒙开发的激情依然没有减退,前几天做了一个鸿蒙的APP,现在给大家分享一下! 具体…...
不再卡顿!如何根据使用需求挑选合适的电脑内存?
电脑运行内存多大合适?在选购或升级电脑时,除了关注处理器的速度、硬盘的容量之外,内存(RAM)的大小也是决定电脑性能的一个重要因素。但究竟电脑运行内存多大才合适呢?这篇文章将帮助你理解不同使用场景下适…...
华为云 云化数据中心 CloudDC | 架构分析与应用场景
云化数据中心 CloudDC 云化数据中心 (CloudDC)是一种满足传统DC客户云化转型诉求的产品,支持将客户持有服务器设备部署至华为云机房,通过外溢华为云的基础设施管理、云化网络、裸机纳管、确定性运维等能力,帮助客户DC快速云化转型。 云化数据…...
【射频仿真学习笔记】变压器参数的Mathematica计算以及ADS仿真建模
变压器模型理论分析 对于任意的无源电路或者等效电路,当画完原理图后,能否认为已经知道其中的两个节点?vin和vout之间的明确解析解 是否存在一个通用的算法,将这里的所有元素都变成了符号,使得这个算法本身就是一个函…...
Linux系统Docker部署开源在线协作笔记Trilium Notes与远程访问详细教程
今天和大家分享一款在 G 站获得了 26K的强大的开源在线协作笔记软件,Trilium Notes 的中文版如何在 Linux 环境使用 docker 本地部署,并结合 cpolar 内网穿透工具配置公网地址,轻松实现远程在线协作的详细教程。 Trilium Notes 是…...
C++基础精讲-01
1C概述 1.1初识C 发展历程: C 由本贾尼・斯特劳斯特卢普在 20 世纪 70 年代开发,它在 C 语言的基础上增加了面向对象编程的特性,最初被称为 “C with Classes”,后来逐渐发展成为独立的 C 语言。 语言特点 (1&#x…...
为什么Java不支持多继承?如何实现多继承?
一、前言 Java不支持多继承(一个类继承多个父类)主要出于文中设计考虑;核心目的是简化语言复杂性并避免潜在的歧义性问题。 二、直接原因:菱形继承/钻石继承问题(Diamond Problem) 假设存在如下继承关系&…...
E8流程多行明细行字符串用I分隔,赋值到主表
需求:明细行摘要字段赋值到主表隐藏字段,隐藏摘要字段在标题中显示 代码如下,代码中的获取字段名获取方式,自行转换成jQuery("#fieldid").val()替换。 //1:参数表单id 2:流程字段名 3:0代表主表,1代表明细…...
QML面试笔记--UI设计篇04交互控件
1. QML中常用交互控件 1.1. Button1.2. Slider1.3. ProgressBar1.4. TextField1.5. TextArea1.6. ComboBox1.7. CheckBox1.8. RadioButton1.9. Menu1.10. Dialog 1. QML中常用交互控件 在万物互联的智能时代,QML凭借其声明式语法和跨平台能力,…...
[特殊字符] Spring Boot 日志系统入门博客大纲(适合初学者)
一、前言 📌 为什么日志在项目中如此重要? 在开发和维护一个后端系统时,日志就像程序运行时的“黑匣子”,帮我们记录系统的各种行为和异常。一份良好的日志,不仅能帮助我们快速定位问题,还能在以下场景中…...
【人工智能】AI大模型开发数学基础指南
目录 学习内容**1. 线性代数****2. 概率与统计****3. 微积分****4. 优化理论****5. 信息论****6. 数值计算****7. 离散数学****8. 统计学进阶****如何学习?****总结** 如何学习**1. 明确学习目标****2. 分阶段学习计划****阶段 1:夯实基础****阶段 2&…...
Express中间件(Middleware)详解:从零开始掌握(1)
1. 中间件是什么? 想象中间件就像一个"加工流水线",请求(Request)从进入服务器到返回响应(Response)的过程中,会经过一个个"工作站"进行处理。 简单定义:中间件是能够访问请求对象(req)、响应对象(res)和下…...
STM32单片机中EXTI的工作原理
目录 1. EXTI概述 2. EXTI的组成部分 3. 工作原理 3.1 引脚配置 3.2 中断触发条件 3.3 中断使能 3.4 中断处理 4. 使用示例 5. 注意事项 结论 在STM32单片机中,EXTI(外部中断)是一种用于处理外部事件的机制,能够提高对硬…...
现代工业测试的核心支柱:电机试验工作台?(北重机械厂家)
电机试验工作台是现代工业测试中的核心支柱之一。这种工作台通常用于对各种类型的电机进行性能测试、负载测试和耐久性测试。通过电机试验工作台,工程师可以评估电机的效率、功率输出、转速、扭矩、温度等关键参数,从而确保电机的设计符合要求࿰…...
oracle 11g密码长度和复杂度查看与设置
verify_function_11G 的密码复杂性要求: 密码长度至少为 8 个字符。 密码必须包含至少一个数字和一个字母字符。 密码不能与用户名相同或相似。 密码不能是服务器名或其变体。 密码不能是常见的弱密码(如 welcome1、oracle123 等)。 注意事项&…...
CVE-2025-32375 | Windows下复现 BentoML runner 服务器远程命令执行漏洞
目录 1. 漏洞描述2. 漏洞复现1. 安装 BentoML 1.4.72. 创建模型3. 构建模型4. 托管模型5. 执行exp 3. POC4. 补充学习 参考链接: https://mp.weixin.qq.com/s/IxLZr83RvYqfZ_eXhtNvgg https://github.com/bentoml/BentoML/security/advisories/GHSA-7v4r-c989-xh26 …...
某局jsvmp算法分析(dunshan.js/lzkqow23819/lzkqow39189)
帮朋友看一个税某局的加密算法。 传送门 (需要帐号登陆的 普通人没授权也看不了) 废话不多说直接抓包开干 这里可以看到一个headers中的加密参数 lzkqow23819 以及url路径里面的6eMrZlPH(这个有点像瑞数里面的) 还有就是cookies里面的这几个…...
深入剖析 Kafka 的零拷贝原理:从操作系统到 Java 实践
Kafka 作为一款高性能的分布式消息系统,其卓越的吞吐量和低延迟特性得益于多种优化技术,其中“零拷贝”(Zero-Copy)是核心之一。零拷贝通过减少用户态与内核态之间的数据拷贝,提升了 Kafka 在消息传输中的效率。本文将…...
AlmaLinux9.5 修改为静态IP地址
查看当前需要修改的网卡名称 ip a进入网卡目录 cd /etc/NetworkManager/system-connections找到对应网卡配置文件进行修改 修改配置 主要修改ipv4部分,改成自己的IP配置 [ipv4] methodmanual address1192.168.252.129/24,192.168.252.254 dns8.8.8.8重启网卡 …...
内联函数通常定义在头文件中的原因详解
什么是内联函数? 内联函数(inline function)是C中的一种函数优化机制,通过在函数声明前加上inline关键字,建议编译器将函数调用替换为函数体本身的代码,从而减少函数调用的开销。 为什么内联函数需要定义…...
操作系统 4.4-从生磁盘到文件
文件介绍 操作系统中对磁盘使用的第三层抽象——文件。这一层抽象建立在盘块(block)和文件(file)之间,使得用户可以以更直观和易于理解的方式与磁盘交互,而无需直接处理磁盘的物理细节如扇区(se…...
免费多语言文档翻译软件推荐
软件介绍 今天给大家介绍一款文档翻译助手。它能够支持PDF、Word等多种文档格式,涵盖中文、英文、日语等多语言互译。此软件在翻译过程中精选保留文档原貌,每段文字、每个图表的匹配都十分完美,还依托顶尖翻译大模型,让翻译结果符…...
安全序列(DP)
#include <bits/stdc.h> using namespace std; const int MOD1e97; const int N1e65; int f[N]; int main() {int n,k;cin>>n>>k;f[0]1;for(int i1;i<n;i){f[i]f[i-1]; // 不放桶:延续前一位的所有方案if(i-k-1>0){f[i](f[i]f[i-k…...
【Flask开发】嘿马文学web完整flask项目第4篇:4.分类,4.分类【附代码文档】
教程总体简介:2. 目标 1.1产品与开发 1.2环境配置 1.3 运行方式 1.4目录说明 1.5数据库设计 2.用户认证 Json Web Token(JWT) 3.书架 4.1分类列表 5.搜索 5.3搜索-精准&高匹配&推荐 6.小说 6.4推荐-同类热门推荐 7.浏览记录 8.1配置-阅读偏好 8.配置 9.1项目…...
SQL开发的智能助手:通义灵码在IntelliJ IDEA中的应用
SQL 是一种至关重要的数据库操作语言,尽管其语法与通用编程语言有所不同,但因其在众多应用中的广泛使用,大多数程序员都具备一定的 SQL 编写能力。然而,当面对复杂的 SQL 语句或优化需求时,往往需要专业数据库开发工程…...
基于 Q - learning 算法的迷宫导航
这段 Python 代码实现了一个基于 Q - learning 算法的迷宫导航系统。代码通过定义迷宫环境、实现 Q - learning 算法来训练智能体,使其能够在迷宫中找到从起点到终点的最优路径,同时利用训练好的 Q 表来测试智能体的导航能力。 在这个代码实现的迷宫环境…...
解决:AttributeError: module ‘cv2‘ has no attribute ‘COLOR_BGR2RGB‘
opencv AttributeError: module ‘cv2’ has no attribute ‘warpFrame’ 或者 opencv 没有 rgbd 解决上述问题的方法是: 卸载重装。 但是一定要卸载干净,仅仅卸载opencv-python是不行的。无限重复都报这个错。 使用pip list | grep opencv查看相关的…...
