指针操作数组

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

指针操作一维整型数组。

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

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

相关推荐
野犬寒鸦26 分钟前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总29 分钟前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow688936 分钟前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
wangjialelele1 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
xuxie991 小时前
day 21 双向链表以及循环链表
数据结构·链表
驱动探索者1 小时前
linux mailbox 学习
linux·学习·算法
ringking1231 小时前
autoware-1:安装环境cuda/cudnn/tensorRT库函数的判断
人工智能·算法·机器学习
大闲在人2 小时前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨2 小时前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑2 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado