指针操作数组

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

指针操作一维整型数组。

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

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在变量声明中使用,使用其他文件中的变量在该文件中声明。

相关推荐
DoraBigHead43 分钟前
小哆啦解题记——异位词界的社交网络
算法
木头左2 小时前
逻辑回归的Python实现与优化
python·算法·逻辑回归
lifallen6 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
web_Hsir8 小时前
vue3.2 前端动态分页算法
前端·算法
地平线开发者10 小时前
征程 6M 部署 Omnidet 感知模型
算法·自动驾驶
秋说11 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法
浩瀚星辰202411 小时前
图论基础算法:DFS、BFS、并查集与拓扑排序的Java实现
java·算法·深度优先·图论
oioihoii14 小时前
C++随机打乱函数:简化源码与原理深度剖析
开发语言·c++·算法
不知名。。。。。。。。14 小时前
分治算法---快排
算法
minji...14 小时前
数据结构 算法复杂度(1)
c语言·开发语言·数据结构·算法