当前位置: 首页 > wzjs >正文

名词解释 网站内容免费网页制作模板

名词解释 网站内容,免费网页制作模板,建设网站硬件需要,抖音小程序搭建双指针: 使用两个指针协同遍历数组/链表&#xff0c;降低时间复杂度&#xff08;通常从O(n)优化到O(n)&#xff09; 典型应用场景 有序数组两数之和 反转数组 移除元素 双指针函数实现和调用示例 //有序数组的两数之和#include <stdio.h>/*** 在有序数组中查找两个数&…

双指针:

使用两个指针协同遍历数组/链表,降低时间复杂度(通常从O(n²)优化到O(n))

典型应用场景
  1. 有序数组两数之和

  2. 反转数组

  3. 移除元素

双指针函数实现和调用示例
//有序数组的两数之和#include <stdio.h>/*** 在有序数组中查找两个数,使它们的和等于目标值* @param nums 有序数组* @param numsSize 数组大小* @param target 目标值* @param returnSize 返回数组大小(固定为2)* @return 两个数的索引数组(从1开始计数)*/
int* twoSum(int* nums, int numsSize, int target, int* returnSize) {int left = 0;int right = numsSize - 1;int* result = (int*)malloc(2 * sizeof(int));*returnSize = 2;while (left < right) {int sum = nums[left] + nums[right];printf("检查 %d + %d = %d\n", nums[left], nums[right], sum); // 流程展示if (sum == target) {result[0] = left + 1; // 题目要求从1开始计数result[1] = right + 1;return result;} else if (sum < target) {left++;printf("和太小,左指针右移 -> [%d]\n", left);} else {right--;printf("和太大,右指针左移 -> [%d]\n", right);}}return result; // 未找到时返回[0,0]
}int main() {int nums[] = {2, 7, 11, 15};int target = 9;int returnSize;int* result = twoSum(nums, sizeof(nums)/sizeof(nums[0]), target, &returnSize);printf("\n最终结果: [%d, %d]\n", result[0], result[1]);free(result);return 0;
}//流程
检查 2 + 15 = 17
和太大,右指针左移 -> [2]
检查 2 + 11 = 13
和太大,右指针左移 -> [1]
检查 2 + 7 = 9最终结果: [1, 2]

滑动窗口:

维护一个动态变化的窗口,用常数时间更新窗口信息

典型应用场景
  1. 最长无重复子串

  2. 最小覆盖子串

  3. 长度最小的子数组

滑动窗口函数实现和调用示例
// 长度最小的子数组
#include <stdio.h>
#include <limits.h>/*** 寻找满足和≥target的最短连续子数组* @param nums 数组* @param numsSize 数组大小* @param target 目标和* @return 子数组长度(不存在返回0)*/
int minSubArrayLen(int* nums, int numsSize, int target) {int left = 0;int sum = 0;int minLen = INT_MAX;for (int right = 0; right < numsSize; right++) {sum += nums[right];printf("窗口扩展: [%d,%d], sum=%d\n", left, right, sum);while (sum >= target) {int currentLen = right - left + 1;if (currentLen < minLen) {minLen = currentLen;printf("找到更小窗口: 长度=%d\n", minLen);}sum -= nums[left++]; // 收缩左边界printf("窗口收缩: [%d,%d], sum=%d\n", left, right, sum);}}return minLen == INT_MAX ? 0 : minLen;
}int main() {int nums[] = {2, 3, 1, 2, 4, 3};int target = 7;int len = minSubArrayLen(nums, sizeof(nums)/sizeof(nums[0]), target);printf("\n最小长度: %d\n", len);return 0;
}//流程
窗口扩展: [0,0], sum=2
窗口扩展: [0,1], sum=5
窗口扩展: [0,2], sum=6
窗口扩展: [0,3], sum=8
找到更小窗口: 长度=4
窗口收缩: [1,3], sum=6
窗口扩展: [1,4], sum=10
找到更小窗口: 长度=4
窗口收缩: [2,4], sum=7
找到更小窗口: 长度=3
窗口收缩: [3,4], sum=6
窗口扩展: [3,5], sum=9
找到更小窗口: 长度=3
窗口收缩: [4,5], sum=7
找到更小窗口: 长度=2
窗口收缩: [5,5], sum=3最小长度: 2

快慢指针

用不同速度移动的两个指针解决链表/数组问题

典型应用场景
  1. 检测链表环

  2. 寻找链表中点

  3. 寻找重复数

快慢指针函数实现和调用示例
//检测链表环#include <stdio.h>
#include <stdbool.h>// 链表节点定义
struct ListNode {int val;struct ListNode *next;
};/*** 检测链表是否有环* @param head 链表头节点* @return 是否有环*/
bool hasCycle(struct ListNode *head) {if (head == NULL) return false;struct ListNode *slow = head;struct ListNode *fast = head->next;int step = 1;while (fast != NULL && fast->next != NULL) {printf("步数%d: 慢指针=%d, 快指针=%d\n", step++, slow->val, fast->val);if (slow == fast) {printf("快慢指针相遇于%d\n", slow->val);return true;}slow = slow->next;         // 慢指针走1步fast = fast->next->next;   // 快指针走2步}return false;
}int main() {// 构建测试链表: 1->2->3->4->2(形成环)struct ListNode node1 = {1, NULL};struct ListNode node2 = {2, NULL};struct ListNode node3 = {3, NULL};struct ListNode node4 = {4, NULL};node1.next = &node2;node2.next = &node3;node3.next = &node4;node4.next = &node2; // 形成环bool result = hasCycle(&node1);printf("\n检测结果: %s\n", result ? "有环" : "无环");return 0;
}//流程
步数1: 慢指针=1, 快指针=2
步数2: 慢指针=2, 快指针=4
步数3: 慢指针=3, 快指针=2
步数4: 慢指针=4, 快指针=4
快慢指针相遇于4检测结果: 有环

技术典型场景时间复杂度空间复杂度核心操作
双指针有序数组操作O(n)O(1)左右指针向中间移动
滑动窗口连续子数组/子串问题O(n)O(1)动态维护窗口边界
快慢指针链表环/中点问题(链表结构分析)O(n)O(1)不同速度移动指针

 

http://www.dtcms.com/wzjs/441455.html

相关文章:

  • 东莞市领导班子深圳seo优化公司搜索引擎优化方案
  • 深圳市建设科技促进中心网站百度上做推广怎么做
  • 教学成果奖网站建设信息检索关键词提取方法
  • wordpress多語言主頁宁波seo服务快速推广
  • 可以做设计兼职的网站有哪些工作查企业信息查询平台
  • 嘉兴营销型网站东莞seo建站排名
  • 网页制作和网站建设发广告去哪个平台
  • 中国互联网百强企业排名优化网站打开速度
  • 漳州做网站的公司第三波疫情将全面大爆发
  • 昆山网站建设公司怎么样网站建设一般多少钱
  • 朝阳市营商环境建设监督局网站培训计划方案模板
  • 在线制作仿真证件生成器淄博网站优化
  • 重庆市住房城乡建设委员会网站网站产品推广
  • 广告设计公司相城黄埭合肥seo整站优化网站
  • 六安做网站公司互联网营销专业
  • 低价网站建设渠道不用流量的地图导航软件
  • 有关做有机肥的企业网站优化手机性能的软件
  • 建站公司人员配置百度seo快速排名
  • 便宜的网站建设学企业管理培训班
  • 网站规划与建设大作业答案平面设计主要做什么
  • 如何做镜像网站专业外贸网络推广
  • 网站ftp做网站的会给嘛口碑营销5t理论
  • 网站建设十年杜绝模板网络营销企业有哪些公司
  • 全部网站seo从零开始到精通200讲解
  • asp婚纱摄影网站源码中文域名交易平台
  • 那个公司做的外贸网站好石家庄seo外包的公司
  • 太原网站建设服务热线seo技巧seo排名优化
  • 1年网站百度账号中心官网
  • 可以建站的网站全球搜索大全
  • 品牌建设内涵网站优化联系