指针操作数组

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

指针操作一维整型数组。

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

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

相关推荐
我是why的狗9 分钟前
赵义弘-----补题报告
算法·排序算法
roman_日积跬步-终至千里1 小时前
【机器学习】两大线性分类算法:逻辑回归与线性判别分析:找到分界线的艺术
算法·机器学习·分类
YuTaoShao1 小时前
【LeetCode 热题 100】739. 每日温度——(解法一)单调栈+从右到左
java·算法·leetcode·职场和发展
Spider_Man1 小时前
栈中藏玄机:从温度到雨水,单调栈的逆袭之路
javascript·算法·leetcode
爱吃KFC的大肥羊2 小时前
C/C++常用字符串函数
c语言·数据结构·c++·算法
im_AMBER2 小时前
Leetcode 11 java
java·算法·leetcode
丶小鱼丶2 小时前
二叉树算法之【Z字型层序遍历】
java·算法
武文斌773 小时前
嵌入式——数据结构:基础知识和链表①
数据结构
岁忧4 小时前
(nice!!!)(LeetCode 每日一题) 2561. 重排水果 (哈希表 + 贪心)
java·c++·算法·leetcode·go·散列表
先做个垃圾出来………4 小时前
1. 两数之和
算法·leetcode·职场和发展