指针操作数组

指针可以实现操作函数和操作数组。

指针操作一维整型数组。

指针操作一维整型数组的时候,需要实现数组的

1、逆序

2、排序、快速排序

3、查找

在指针操作的过程中一般函数的传参都是*begin *end

使用指针实现数组逆序

使用指针实现排序

快速排序的思想

第一步:确定一个基准位置。

第二步:从右端end开始寻找一个比基准值小的数。

第三步:从左端begin开始寻找一个比基准值大的数。

第四步:交换找到的两个值。

第五步:当begin与end重合时,交换基准值与相遇值。

第六步:再次调用该函数形成递归,不过左右端的地址修改

第七步:当begin>end,返回return ;即停止循环。

cs 复制代码
#if 1
void swap(int * a, int * b)
{
    int t = *a;
    *a = *b;
    *b = t;
}
void quickSort(int * begin, int * end)
{
    int * left = begin;
    int * right = end;
    int * k = begin;

    while(begin  <= end)
    {
        if(begin < end && *end > *k)
        {
            --end;
        }
        if(begin < end && *begin < *k)
        {
            ++begin;
        }
        swap(begin,end); //如果找到不满足以上if的交换两个值
    }
    swap(begin,k);  //一旦外层begin开始大于end说明一层循环结束,交换最终begin和end停留的位置和基准位置上的值。
    
    quickSort(left, end - 1);
    quickSort(begin + 1, right);    //此时的begin与end已经相遇,即相等
    
}
#endif
void severSort(int * begin, int  * end)
{
    while(begin < end)
    {
        char t = *begin;
        *begin = *end;
        *end = t;
        ++begin;
        --end;
    }
}
int main()
{
    char s[] = "how are you";
    severSort(s, s+10);
}

static 修饰局部变量和全局变量,将变量定义在静态区,延长变量的生命周期。其特点是只能被初始化一次,其值具有继承性。

与extern在变量声明中使用,使用其他文件中的变量在该文件中声明。

相关推荐
码农多耕地呗36 分钟前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存
晚枫~1 小时前
数据结构基石:从线性表到树形世界的探索
数据结构
hadage2332 小时前
--- 数据结构 AVL树 ---
数据结构·算法
liu****2 小时前
8.list的使用
数据结构·c++·算法·list
立志成为大牛的小牛2 小时前
数据结构——二十六、邻接表(王道408)
开发语言·数据结构·c++·学习·程序人生
阿拉丁的梦2 小时前
后期材质-屏幕冲击径向模糊
算法·材质
weixin_429630262 小时前
实验二-决策树-葡萄酒
算法·决策树·机器学习
茉莉玫瑰花茶3 小时前
floodfill 算法(dfs)
算法·深度优先
CoderCodingNo3 小时前
【GESP】C++五级考试大纲知识点梳理, (5) 算法复杂度估算(多项式、对数)
开发语言·c++·算法
学编程就要猛3 小时前
数据结构初阶:时间和空间复杂度
数据结构