首页 > 其他分享 >数组2

数组2

时间:2022-12-06 23:00:37浏览次数:37  
标签:sz arr int 数组名 数组 printf sizeof

数组作为函数参数

冒泡排序

#include <stdio.h>
viod bubble_sort(int arr[])
{
int i=0;
int sz=sizeof(arr)/sizeof(arr[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 temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}
int main()
{
int arr[]={9,8,7,6,5,4,3,2,1};
int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
bubble_sort(arr);
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}

这个代码是错误的,无法完成排序,我们进行调试后,发现到bubble_sort 函数内部的sz ,是1。因为,arr是数组,我们对数组arr进行传参,实际上传递过去的是数组arr首元素的地址,其实传过去的就是&arr[0],所以bubble_sort 函数内部的sz ,是1。

#include <stdio.h>
viod 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 temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}
int main()
{
int arr[]={9,8,7,6,5,4,3,2,1};
int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
bubble_sort(arr,sz);
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}

我们发现,如果是这样数组{9,1,2,3,4,5,6,7,8},上述代码也可以实现排序,但是做了很多无用的冒泡排序,所以我们可以对此进行优化

#include <stdio.h>
viod bubble_sort(int arr[],int sz)
{
int flag=1;//假设这一趟要排序的数据已经有序
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 temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
int flag=0;//本趟排序数据其实不完全有序
}
}
if (flag == 1)
{
break;
}
}
}
int main()
{
int arr[]={9,8,7,6,5,4,3,2,1};
int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
bubble_sort(arr,sz);
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}

数组名是什么?

#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5};
printf("%p\n", arr);
printf("%p\n", &arr[0]);
printf("%d\n", *arr);
return 0;
}

输出结果:

数组2_数组

结论:数组名是数组首元素的地址

但是:有两种情况例外

int sz = sizeof(arr) / sizeof(arr[0]);

1.sizeof(数组名)-数组名表示整个数组,sizeof(数组名)计算的是整个数组的大小,单位是字节

2.&数组名,数组名代表整个数组,&数组名,取出的是整个数组的地址

#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5};
printf("%p\n", arr);
printf("%p\n", &arr[0]);
printf("%p\n", &arr);
return 0;
}

输出结果:3个输出的结果是一样的,数组名是数组首元素的地址

数组2_数组_02

#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5};
printf("%p\n", arr);
printf("%p\n", arr+1);

printf("%p\n", &arr[0]);
printf("%p\n", &arr[0]+1);

printf("%p\n", &arr); //&arr-数组的地址
printf("%p\n", &arr+1);
return 0;
}

输出结果:

数组2_i++_03




标签:sz,arr,int,数组名,数组,printf,sizeof
From: https://blog.51cto.com/u_15894225/5916691

相关文章

  • 数组:内存分析及三种初始化
    数组(堆和栈的关系)内存分析:通常我们说的分析java内存,指的是分析java的堆内存(heapmemory),稍微扩展点,还可能涉及到持久带内存(jre7以前)或者Metaspace(jre8以后)。.一般的垃圾......
  • 树状数组统计一个数前面有几个数比它小,有几个数比它大
    很重要的算法,蓝桥杯遇到n次了#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;intn,m;inta[1000010],c[1000010],b[1000010];intlowbit(intx......
  • 快速找出数组中两数的和
    原文:https://blog.csdn.net/weixin_30591551/article/details/94977311能否快速找出一个数组中的两个数字,让这两个数字之和等于一个给定的值,为了简化起见,我们假设这个数组......
  • 第二节-创建数组与属性-checkpoint
    创建ndarray对象通过NumPy的内置函数array()可以创建ndarray对象,其语法格式如下:numpy.array(object,dtype=None,copy=True,order=None,subok=False,ndmin......
  • 数组和集合的增强for
    数组的增强for@Testpublicvoidtest1(){Integer[]integers=newInteger[5];for(inti=0;i<integers.length;i++){integers[i]=i;}......
  • 数组-Array
    数组(Array)是一种线性表数据结构。它用一组连续的内存空间,来存储一组具有相同类型数据的集合。  数组的特点:1.数组是相同数据类型的集合。(int类型的数组不能放double......
  • Go-09 Go语言中数组、切片的排序算法以及sort包
    packagemainimport( "fmt" "sort")//Golang数组中的切片及sort包funcmain(){ //1.选择排序 varnumSlice=[]int{9,8,7,6,5,4} fori:=0;i<le......
  • 05 Java 数组
    Java数组一、什么是数组数组是相同类型数据的有序集合数组描述的是相同类型的若干个数据,按照一定的顺序排列组合而成其中每一个数据称为数组元素,每个数组元素可以通过......
  • vue 数组转组织树
    //树节点中查询遍历组织getNode(data,key,val){lettreeNode="";data.some(item=>{letflag=false;console.log("item[......
  • 连续子数组的最大和
    public class Solution {    public int FindGreatestSumOfSubArray(int[] array) {        int[] dp = new int[array.length];     ......