算法学习记录DAY1

题源(力扣平台)

解题算法原理:

数组划分/分块题:"双指针"算法---利用数组下标充当"双指针"

为什么?

1.题目要求不创建新的数组空间

2.利用数组下标"随机存取、访问元素"的性质

核心是对数组元素进行分类,分了两大类,在遍历元素进行处理的时候需要第一个cur指针,用来区分已处理和未处理的元素;而另一个des指针则是用于区分已处理的元素中分属地两类

cpp 复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        // //数组长度<=1,无需交换
        // if(nums.size() <= 1) return;
        // //定义双指针
        // int des = -1, cur = 0, n = nums.size();
        // //用于元素交换
        // int tmp = 0;
        // //循环结束条件
        // while(cur < n){
        //     if(nums[cur] == 0) cur++;
        //     else{
        //         tmp = nums[des + 1];
        //         nums[des + 1] = nums[cur];
        //         nums[cur] = tmp;
        //         des++;
        //         cur++;
        //     }
        // }
        // return ;
        for(int des = -1, cur = 0; cur < nums.size(); cur++){
            if(nums[cur] != 0){
                swap(nums[++des], nums[cur]);
            }
        }
    }
};

注释部分是自己写的代码

与参考代码相比

可优化点:

1.变量的"可见范围"

复制代码
// 写法 A - 函数级作用域
int des = -1, cur = 0;
while(cur < n) { ... }
// ❓ 这里 des 和 cur 还能被访问到吗?

// 写法 B - 循环级作用域  
for(int des = -1, cur = 0; ...; ...) { ... }
// ❓ 这里 des 和 cur 还能被访问到吗?

问题1:哪种写法能防止后续代码意外修改这两个变量?

2:代码意图

当看到 for(int des = -1, ...) 时,能不能立刻知道:

  • des 只在这个循环里使用?
  • 循环结束后它就不再重要了?

对比 :如果写在函数开头,后面还有 50 行代码,读者需要怎样判断 des 的使用范围?

3:初始化时机

复制代码
// A
int des = -1;
// ... 中间可能有其他代码 ...
for(; cur < n; ) { ... }

// B
for(int des = -1; ...; ...) { ... }

问题 :哪种写法能保证 des 一定在使用前被正确初始化?

核心原则

"变量应该在其最小必要作用域内声明"

  1. 减少意外错误 - 作用域外无法访问
  2. 代码更清晰 - 声明靠近使用位置
  3. 便于维护 - 修改时影响范围更小

以上来自AI给出的优化原因

在今后的代码书写中,要遵循"将变量在最近的作用域中优化"的原则

相关推荐
nashane1 小时前
HarmonyOS 6商城开发学习:消息中心未读清零——@ObservedV2+@Trace驱动一键清除
学习·华为·harmonyos
Litluecat1 小时前
配合多角色提示语,学习AI漫剧(刚开始学)
人工智能·学习·机器学习·ai·提示词·漫剧
MZZ骏马1 小时前
C++ 极简模式的日志
c++
AbandonForce2 小时前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
xian_wwq2 小时前
【学习笔记】「大模型安全:攻击面演化史」第 02 篇-越狱攻防战
笔记·学习
数智工坊2 小时前
【ROS 2 全栈入门指南三】:Action、参数与Launch文件全链路指南
android·stm32·嵌入式硬件·学习·机器人
Kobebryant-Manba2 小时前
学习automl
学习
小欣加油2 小时前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
J.Kuchiki2 小时前
【PostgreSQL 内核学习:平衡 K 路归并(Balanced k-way Merge)】
数据库·学习·postgresql