void bubble_sort(int arr[], int sz)
//{
int i = 0;
for (i = 0; i < sz - 1; i++)
{
int j = 0;
for (j = 0; j < sz - 1 - i; j++)
{
if (arr[j] > arr[j + 1])
{
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
}
int main()
{
int arr[] = {9,8,7,6,5,4,3,2,1,0};
int sz = sizeof(arr) / sizeof(arr[0]);//
bubble_sort(arr,sz);
//int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}//
arr传入的时候难道不是传的数组首元素地址,也就是&arr[0]吗,那下面冒泡排序为啥能把后面没有传入的元素给排了(有人说数组内存是连续的,首元素传进去,后面依次就有了)
int my_strlen(char* arr)
//{
if (*arr != '\0')
return 1 + my_strlen(arr+1);
else
return 0;
}
int main()
{
char arr[] = "bit";
int arr1[] = { 1,2,3 };
int i = 0;
int b = 0;//
int len = my_strlen(arr);
//printf("%d\n", len);
return 0;
}//
那这个arr传入时,为什么要用指针形式,不能用上面的int arr[]接收。