跳到主要内容
极客日志极客日志
首页博客AI提示词GitHub精选代理工具
搜索
|注册
重置
编程语言 / C

标签

全部标签AIjavaNode.jsNuctPayPPT制作React NativeRNSaaSWeChat大前端算法

分类

全部分类
编程语言
PythonJavaScriptTypeScriptJavaKotlinGo / GolangRustC++CC#F#PHPRubySwiftObjective-CScalaClojureElixirErlangHaskellDartLuaPerlRJuliaMATLAB / OctaveSQLShell / BashPowerShellHTML / CSSZigNimCrystalGroovyVisual Basic .NETSolidity汇编

排序

最新更新最新发布最多浏览最多点赞
Linux 缓冲区和文件系统
C

Linux 缓冲区和文件系统

Linux 缓冲区和文件系统涉及用户空间缓冲机制与存储设备逻辑地址管理。FILE 结构体封装了文件描述符 fd 及缓冲区,缓冲区位于用户空间。C 标准库提供全缓冲、行缓冲和无缓冲三种模式,换行或进程退出会触发刷新。系统调用 write 绕过 C 缓冲区直接写入内核。fork 操作会导致父子进程共享缓冲区,进程结束时的刷新可能引发写时拷贝导致数据重复打印。文件系统方面,固态硬盘基于 NAND 闪存,通过 FTL 映射逻辑地址到物理地址。L…

清心发布于 2026/3/16更新于 2026/4/2211 浏览3 点赞约 21 分钟阅读
数据结构:双链表详解
C算法

数据结构:双链表详解

双链表是一种每个节点包含前驱和后继指针的线性表结构,支持双向遍历。双链表的基本概念与实现方案,包括节点结构体定义(含数据域、前驱指针、后继指针)、文件组织方式(头文件声明、源文件实现、测试文件)以及核心接口设计。涵盖初始化、打印、头尾插删、指定位置插入删除及查找等功能,采用哨兵位简化操作,确保内存安全与接口一致性。

追风少年发布于 2026/3/16更新于 2026/4/2110 浏览2 点赞约 3 分钟阅读
C算法

数据结构:双向循环链表实现

双向循环链表的数据结构概念及其在 C 语言中的具体实现。通过引入哨兵位头节点简化了边界处理逻辑,详细阐述了初始化、销毁、头尾插入删除、元素查找及打印等核心功能的代码编写方法。文中提供了完整的头文件与源文件示例,展示了如何利用 prev 和 next 指针构建双向循环结构,并包含测试用例验证功能正确性。适合需要掌握基础数据结构实现的开发者参考。

无尘发布于 2026/3/16更新于 2026/4/2210 浏览2 点赞约 21 分钟阅读
顺序表:数据结构中的基础存储实现
C算法

顺序表:数据结构中的基础存储实现

顺序表是线性表的顺序存储结构,采用物理地址连续的存储单元依次存放数据元素。主要涵盖概念定义、静态与动态分类、核心接口实现(初始化、扩容、增删查改、查找、销毁、打印)以及优缺点分析。通过 C 语言代码演示了动态顺序表的具体逻辑,并结合典型算法面试题展示实际应用。

晚风叙旧发布于 2026/3/16更新于 2026/4/216 浏览1 点赞约 12 分钟阅读
Modbus CRC16 算法规范与计算示例
C算法

Modbus CRC16 算法规范与计算示例

Modbus CRC16 算法基于多项式 x^16 + x^15 + x^2 + 1,初始值 0xFFFF。计算时逐字节处理,先与 CRC 低字节异或,右移一位,若移出位为 1 则异或 0xA001。最终 CRC 值低字节在前传输。示例帧 01 03 00 00 00 01 的 CRC 结果为 0x0A84,实际发送顺序为 84 0A。

灵魂伴侣发布于 2026/3/16更新于 2026/4/217 浏览0 点赞约 8 分钟阅读
Linux 进程与 fork 系统调用详解
C算法

Linux 进程与 fork 系统调用详解

Linux 进程标识符 PID 用于唯一标识进程。通过 ps 命令可查看所有进程,kill 命令可终止进程。fork 系统调用创建子进程,父子进程共享代码段,数据段采用写时拷贝技术保证独立性。调度器决定进程运行顺序,支持并发执行。Bash 执行命令时隐式调用 fork 创建子进程。理解这些机制有助于掌握操作系统多任务管理。

开源信徒发布于 2026/3/16更新于 2026/4/213 浏览0 点赞约 30 分钟阅读
STC 单片机摄像头组别图像优化与搜线算法实战
C算法

STC 单片机摄像头组别图像优化与搜线算法实战

STC 单片机摄像头组别面临图像处理卡顿问题。核心症结为内存不足与算法计算耗时过长。通过灰度图二值化基础解析,采用大津法自动筛选阈值。优化方案包括图像下采样(188x120 降至 94x60)降低内存与遍历次数,以及帧间采样复用阈值减少重复计算。实测单帧耗时从 20ms 降至 9-11ms。搜线算法对比八邻域与最长白列法,推荐优先选用八邻域搜线法以提升效率与稳定性,兼顾资源占用与场景适配。

月亮邮递员发布于 2026/3/16更新于 2026/4/212 浏览0 点赞约 29 分钟阅读
LeetCode 964. 最少运算符表示数字
C算法

LeetCode 964. 最少运算符表示数字

该问题要求使用给定的正整数 x 和加减乘除运算符构建表达式,使其结果等于目标值 target,并求最少运算符数量。解题思路采用深度优先搜索(DFS)配合记忆化搜索。对于小于等于 x 的数直接计算,对于大数则寻找最接近的 x 的幂次,分别尝试向下取整(undershoot)和向上取整(overshoot)两种策略,递归求解剩余部分的最小操作数。

灵魂摆渡发布于 2026/3/16更新于 2026/4/217 浏览1 点赞约 6 分钟阅读
数据结构初阶:计数排序算法详解
C算法

数据结构初阶:计数排序算法详解

计数排序是一种线性时间复杂度的非比较排序算法,通过统计元素出现次数确定位置。相比绝对位置,相对位置能优化空间使用,尤其适合最小值较大的场景。阐述了算法原理、相对位置映射方法,并提供了 C 语言代码实现,分析了其适用性与局限性。

怪力乱神发布于 2026/3/16更新于 2026/4/217 浏览1 点赞约 5 分钟阅读
C

Linux 进程控制:终止、等待与程序替换

Linux 进程控制主要涵盖进程终止、进程等待和程序替换三个核心部分。进程终止通过 return、exit 或_exit 实现,区别在于缓冲区处理。进程等待用于避免僵尸进程并获取退出状态,使用 waitpid 配合宏解析 status 参数。程序替换通过 exec 家族函数加载新程序,保持进程 ID 不变。

未来可期发布于 2026/3/16更新于 2026/4/2210 浏览1 点赞约 16 分钟阅读
数据结构:单链表的概念、结构与实现
C算法

数据结构:单链表的概念、结构与实现

链表是一种物理存储结构上非连续、非顺序的线性表,通过指针链接次序实现逻辑顺序。介绍单链表的基本概念、结点结构(数据 + 指针)、性质及打印实现方法。对比顺序表,链表无需增容,按需申请空间。内容涵盖单链表分类、头文件与实现文件的组织方式,以及完整的 C 语言代码示例,帮助理解链表的内存分配与遍历逻辑。

ApiHolic发布于 2026/3/16更新于 2026/4/229 浏览0 点赞约 6 分钟阅读
归并排序非递归实现指南
C算法

归并排序非递归实现指南

归并排序非递归实现采用自底向上策略,通过步长 gap 控制子数组合并。初始 gap 为 1,两两合并有序子序列,随后 gap 翻倍直至覆盖整个数组。相比递归版本,非递归无需栈空间且逻辑固定,但需手动处理边界越界情况,如右区间超出数组长度时需修正 end2。核心流程包括初始化临时数组、循环合并及数据回写,时间复杂度 O(nlogn),空间复杂度 O(n)。

落日余晖发布于 2026/3/16更新于 2026/4/212 浏览0 点赞约 17 分钟阅读
数据结构:栈和队列的定义与实现
C算法

数据结构:栈和队列的定义与实现

栈是一种后进先出的线性表,仅允许在栈顶进行插入和删除操作,通常使用顺序表实现以方便动态增容。队列是先进先出的线性表,在队尾插入、队头删除,为避免数据移动效率问题常采用单链表实现。文章详细阐述了两种结构的定义、特点,并给出了基于 C 语言的完整接口声明与核心函数实现代码,涵盖初始化、入栈/入队、出栈/出队、获取栈顶/队头元素及销毁等关键功能。

微码行者发布于 2026/3/16更新于 2026/4/227 浏览1 点赞约 10 分钟阅读
C 语言快速排序算法详解与优化实现
C算法

C 语言快速排序算法详解与优化实现

快速排序是常用的高效排序算法。文章详细讲解了基于 Hoare 分区的快速排序实现,包括基准值选取、左右指针交换及区间划分逻辑。针对最坏情况提出三数取中优化,避免极端数据导致性能下降。针对小区间递归效率低的问题,引入堆排序进行优化。最后展示了使用栈模拟递归的非递归实现方案,有效防止栈溢出风险。涵盖基础原理、代码优化及完整 C 语言实现示例。

晚风告白发布于 2026/3/16更新于 2026/4/213 浏览0 点赞约 23 分钟阅读
Linux 进程替换原理:从 fork 到 exec 详解
C

Linux 进程替换原理:从 fork 到 exec 详解

Linux 进程替换指用新可执行程序完全替换当前进程的代码、数据和堆栈,PID 保持不变。核心流程为 fork 创建子进程后调用 exec 系列函数。exec 不会触发写时拷贝,因它丢弃原有地址空间。CPU 通过 ELF 文件头 e_entry 字段获取入口地址。exec 系列库函数封装了底层 execve 系统调用,支持不同参数传递方式(可变参数或数组)。父进程可通过 fork 继承环境变量,或使用 execle/execvpe 显式…

SqlMaster发布于 2026/3/16更新于 2026/4/231 浏览0 点赞约 28 分钟阅读
Linux 文件操作核心:缓冲区机制与文件描述符原理
C

Linux 文件操作核心:缓冲区机制与文件描述符原理

Linux 文件操作中,C 标准库通过用户级缓冲区减少系统调用次数以提升效率。解析文件描述符与缓冲区的交互机制,对比 printf/fwrite/write 的输出差异及刷新策略(无缓冲、行缓冲、全缓冲)。通过模拟实现简易 C 文件库,展示_fopen、_fwrite、_fclose 等函数如何封装 open/write/close 系统调用,阐明进程退出时缓冲区刷新的关键逻辑。

灭霸发布于 2026/3/15更新于 2026/4/219 浏览1 点赞约 35 分钟阅读
数据结构入门:带头双向循环链表实现
C算法

数据结构入门:带头双向循环链表实现

带头双向循环链表的数据结构定义及核心接口实现,包括节点创建、初始化、销毁、打印、判空、头尾插删、查找及指定位置插入删除。通过对比顺序表与链表特性,阐述了链表在频繁增删场景下的优势,并提供了完整的 C 语言代码示例(List.h 与 List.c),帮助理解双链表指针操作逻辑。

人间失格发布于 2026/3/15更新于 2026/4/218 浏览1 点赞约 20 分钟阅读
数据结构:栈与队列的实现及应用
C算法

数据结构:栈与队列的实现及应用

栈(后进先出)和队列(先进先出)的基本概念及结构特点。详细阐述了使用数组实现栈和使用链表实现队列的 C 语言代码逻辑,包括初始化、增删改查及销毁操作。此外,通过括号匹配问题演示了栈的实际应用,并提供了使用两个队列模拟栈结构的具体算法实现方案。

字节跳动发布于 2026/3/15更新于 2026/4/227 浏览1 点赞约 21 分钟阅读
递归算法:二叉树遍历的核心实现
C算法

递归算法:二叉树遍历的核心实现

递归算法用于解决二叉树相关经典问题。涵盖单值二叉树判断、两树是否相同、子树匹配及对称性检测。核心思路利用递归函数比较节点值与结构,时间复杂度通常为 O(N)。代码基于 C 语言实现,包含详细逻辑分析与示例。

刀狂发布于 2026/3/15更新于 2026/4/231 浏览0 点赞约 10 分钟阅读
数据结构:八种常见排序算法
C算法

数据结构:八种常见排序算法

八种常见排序算法涵盖插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序及计数排序。内容包含各算法基本思想、C 语言代码实现、时间复杂度与空间复杂度分析、稳定性对比。重点解析快速排序的 Hoare、挖坑法、Lomuto 分区策略及非递归实现,归并排序分治逻辑,以及计数排序适用场景。适合数据结构学习与算法性能评估参考。

萤火微光发布于 2026/3/15更新于 2026/4/213 浏览0 点赞约 39 分钟阅读
上一页下一页