#include<cstdio>
#include<iostream>
using namespace std;
int arr[10000];
void Quick_Sort(int *arr, int begin, int end)//这个*arr和arr[]有什么关系,我对指针不是很熟悉,能详细讲一下吗
{
if(begin > end)
return;
int tmp = arr[begin];
int i = begin;
int j = end;
while(i != j)
{
while(arr[j] >= tmp && j > i)
j--;
while(arr[i] <= tmp && j > i)
i++;
if(j > i)
{
int t = arr[i];
arr[i] = arr[j];
arr[j] = t;
}
}
arr[begin] = arr[i];
arr[i] = tmp;
Quick_Sort(arr, begin, i-1);
Quick_Sort(arr, i+1, end);
}
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>arr[i];
}
Quick_Sort(arr, 1, n);
for(int i=1;i<=n;i++)
{
cout<<arr[i]<<" ";
}
return 0;
}
![](https://profile-avatar.csdnimg.cn/497b30341bf744b29fac7d7dee4b100f_qq_45448418.jpg!4)
c++数组指针编程的一个小问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- ShowMeAI 2023-01-05 13:42关注
你的代码程序是一个快速排序的例子。
- 在函数 Quick_Sort 中,arr 是一个数组名,它代表数组的第一个元素的地址。*arr 是一个指针,它指向数组第一个元素的地址。arr[] 是一个数组,它的元素可以通过下标访问。
- 数组名作为指针的使用是一种特殊情况,即数组名可以自动转换为指向数组第一个元素的指针。这也是为什么 arr 和 &arr[0] 是等价的。
- 在函数调用 Quick_Sort(arr, 1, n) 中,arr 作为参数传递给函数时,它被当做指针使用,因此 Quick_Sort 函数中的 arr 就是一个指针,它指向传递给函数的数组的第一个元素的地址。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 网络科学导论,网络控制
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)