c++学习笔记1——改变子函数数组值会影响主函数的数组的值吗?

下面的函数是用于测试,改变子函数中数组的数值,是否会改变主函数的值的两种方法。

#include<iostream>
#include<cstdio>

using namespace std;


//下面用的是冒泡排序方法,利用指针的方式传值
void insertsortnew(int *p, int n)
{
    int j = 0;//下标为0的用于临时存储的变量
    int tmp = 0;
    for (int i = 2; i < n+1; i++)
    {
        if (*(p+i) < *(p+i-1))//找到较小的值
        {
            tmp = *(p + i);
            //从前到后进行从小到达的排序
            for (j = i - 1; tmp < *(p + j); j--)
            {
                *(p + j + 1) = *(p + j);
            }
            *(p + j + 1) = tmp;
        }
    }
    for (int i = 1; i < n + 1; i++)
    {
        cout << *(p + i) << endl;
    }
}

//下面用的是冒泡排序方法,直接使用数组传值
void insertsort(int arr[], int n)
{
    int j = 0;//下标为0的用于临时存储的变量
    for (int i = 2; i < n+1; i++)
    {
        if (arr[i] < arr[i - 1])//找到较小的值
        {
            arr[0] = arr[i];
            //从前到后进行从小到达的排序
            for (j = i - 1; arr[0] < arr[j]; j--)
            {
                arr[j + 1] = arr[j];
            }
            arr[j + 1] = arr[0];
        }
    }
    
}


int main(){
    int n, a;    //n代表输入参数的个数
    int A[100];
    cin >> n ;
    cout << n << endl;

    int tmp = 0;
    while (tmp<n)
    {
        int x; scanf_s("%d", &x);
        A[tmp+1] = x;
        tmp++;
    }
    int B[10];
    //这里创建一个新的数组,备份A数组的值
    for (int i = 0; i < n + 1;i++)
    {
        B[i] = A[i];
    }  

    cout << "用指针方式进行传值" << endl;
    insertsortnew(A, n);
    cout << "直接传递数组" << endl;
    insertsort(B, n);
    for (int i = 1; i < n+1; i++)
    {
        cout << B[i] << endl;
    }
    system("pause");
    return 0;
    
}

总结:虽然上述两种方法都可以改变主函数中数组的值,但是采用指针的方式不需要在子函数中copy新的数组,效率会比较高一些。

从结果可以看出,两种方法都改变了主函数中数组的值。但是我们还是要区分一下数组和指针:

1、数组不是指针,数组中有数组长度信息,指针没有;

2、作为函数参数时,数组会被看成指针。
 

扫描二维码关注公众号,回复: 5520265 查看本文章

猜你喜欢

转载自blog.csdn.net/weixin_42056625/article/details/88393116