数组名作函数参数和指针变量作函数参数

原创 2017年03月09日 20:41:43

数组名作函数参数和指针变量作函数参数

题目:输入5个整数,并为其中的前n个整数从小到大进行排序;

四种情况:
Example1: 数组名作实参,数组名作形参;

#include <stdio.h>
int main()
{//输入5个整数,并为其中的前n个整数从小到大进行排序;

    int sort(int a[],int n);
    int array[5],num;
    printf("Please enter 5 number:\n");
    for(int i=0;i<5;i++)
        scanf("%d",&array[i]);
    printf("How many numbers do you want to sort:\n");
    scanf("%d",&num);
    sort(array,num);
    for(int j=0;j<5;j++)
        printf("%d\t",array[j]);
    printf("\n");
    return 0;
}
int sort(int a[],int n)
{
    int k;
    //选择排序法:(1)第一轮:先找出所有数的中最小的数,并让其和第一个数交换位置;
    //            (2)第二轮:第一个数不变,在第二个数到最后一个数之间找出最小的数,并让其和第二个数交换位置;
    //             (3) 重复以上操作,直到进行(n-1)轮排序为止,此时已排好了前(n-1)个数的顺序,最后一个数自然是最大的;
    for(int i=0;i<n;i++)
    {
        k=i;
        for(int j=i+1;j<n;j++)
            if(a[k]>a[j]) k=j;//找出从a[i+1]到a[n-1]之间的最小的数的位置;
            if(k!=i)
            {
                int temp;
                temp=a[k];
                a[k]=a[i];
                a[i]=temp;
            }
    }
    return 0;
}

Example2:指针变量作实参,数组名作形参;

#include <stdio.h>
int main()
{//输入5个整数,并为其中的前n个整数从小到大进行排序;

    int sort(int a[],int n);
    int array[5],num,*p;
    p=array;//指针变量p指向array[0];
    printf("Please enter 5 number:\n");
    for(int i=0;i<5;i++)
        scanf("%d",p++);//输入的整数依次存储到指针变量p所指向的存储单元中;
    printf("How many numbers do you want to sort:\n");
    scanf("%d",&num);
    p=array;//关键一步:注意一定要重新将指针变量p赋值为&array[0];因为经过第一个for循环p的值为&array[5];
    sort(p,num);//注意"p=array"必须在前面
    for(int j=0;j<5;j++)
    {
        printf("%d\t",*p);
        p++;
    }
    printf("\n");
    return 0;
}
//数组作形参
int sort(int a[],int n)
{
    int k;
    //选择排序法:(1)第一轮:先找出所有数的中最小的数,并让其和第一个数交换位置;
    //            (2)第二轮:第一个数不变,在第二个数到最后一个数之间找出最小的数,并让其和第二个数交换位置;
    //             (3) 重复以上操作,直到进行(n-1)轮排序为止,此时已排好了前(n-1)个数的顺序,最后一个数自然是最大的;
    for(int i=0;i<n;i++)
    {
        k=i;
        for(int j=i+1;j<n;j++)
            if(a[k]>a[j]) k=j;//找出从a[i+1]到a[n-1]之间的最小的数的位置;
            if(k!=i)
            {
                int temp;
                temp=a[k];
                a[k]=a[i];
                a[i]=temp;
            }
    }
    return 0;
}

Example3:指针变量作实参,指针变量作形参;

#include <stdio.h>
int main()
{//输入5个整数,并为其中的前n个整数从小到大进行排序;

    int sort(int *a,int n);//指针变量作形参
    int array[5],num,*p;
    p=array;//指针变量p指向array[0];
    printf("Please enter 5 number:\n");
    for(int i=0;i<5;i++)
        scanf("%d",p++);//输入的整数依次存储到指针变量p所指向的存储单元中;
    printf("How many numbers do you want to sort:\n");
    scanf("%d",&num);
    p=array;//关键一步:注意一定要重新将指针变量p赋值为&array[0];因为经过第一个for循环p的值为&array[5];
    sort(p,num);
    for(int j=0;j<5;j++)
    {
        printf("%d\t",*p);
        p++;
    }
    printf("\n");
    return 0;
}
//指针变量作形参
int sort(int *a,int n)
{
    int k;
    //选择排序法:(1)第一轮:先找出所有数的中最小的数,并让其和第一个数交换位置;
    //            (2)第二轮:第一个数不变,在第二个数到最后一个数之间找出最小的数,并让其和第二个数交换位置;
    //             (3) 重复以上操作,直到进行(n-1)轮排序为止,此时已排好了前(n-1)个数的顺序,最后一个数自然是最大的;
    for(int i=0;i<n;i++)
    {
        k=i;
        for(int j=i+1;j<n;j++)
            if(*(a+k) > *(a+j)) k=j;//找出从a[i+1]到a[n-1]之间的最小的数的位置;(事实上就是把*(a+k)和a[k]等价,下同)
            if(k!=i)
            {
                int temp;
                temp=*(a+k);
                *(a+k)=*(a+i);
                *(a+i)=temp;
            }
    }
    return 0;
}

Example4:数组名作实参,指针变量作形参;

#include <stdio.h>
int main()
{//输入5个整数,并为其中的前n个整数从小到大进行排序;

    int sort(int *a,int n);//指针变量作形参
    int array[5],num;
    printf("Please enter 5 number:\n");
    for(int i=0;i<5;i++)
        scanf("%d",&array[i]);
    printf("How many numbers do you want to sort:\n");
    scanf("%d",&num);
    sort(array,num);
    for(int j=0;j<5;j++)
    {
        printf("%d\t",array[j]);
    }
    printf("\n");
    return 0;
}
//指针变量作形参
int sort(int *a,int n)
{
    int k;
    //选择排序法:(1)第一轮:先找出所有数的中最小的数,并让其和第一个数交换位置;
    //            (2)第二轮:第一个数不变,在第二个数到最后一个数之间找出最小的数,并让其和第二个数交换位置;
    //             (3) 重复以上操作,直到进行(n-1)轮排序为止,此时已排好了前(n-1)个数的顺序,最后一个数自然是最大的;
    for(int i=0;i<n;i++)
    {
        k=i;
        for(int j=i+1;j<n;j++)
            if(*(a+k) > *(a+j)) k=j;//找出从a[i+1]到a[n-1]之间的最小的数的位置;(事实上就是把*(a+k)和a[k]等价,下同)
            if(k!=i)
            {
                int temp;
                temp=*(a+k);
                *(a+k)=*(a+i);
                *(a+i)=temp;
            }
    }
    return 0;
}

参考:《C语言程序设计》谭浩强版

如有错误,欢迎指正!谢谢!

数组名,指针变量作函数参数的四种情况

函数的参数可以是变量,也可以是数组。当整个数组作为函数的参数时,实际上是数组的地址作为参数。由于实参可以是表达式,数组元素也可以是表达式的一部分,因此,数组元素可以作为函数的实参,这时对应的形参应该是...

关于指针变量作函数参数的几点注意

关于指针变量作函数参数的几点注意 题目:输入两个整数,并按从小到大的顺序输出这两个整数。...

指针变量作为函数参数

先描述一个题目,题目是这样的,输入a和b两个整数,按先大后小的顺序输出a和b。` /* Note:Your choice is C IDE */ #include "stdio.h" void mai...

C语言指针变量作为函数参数

C语言指针变量作为函数参数

指针变量作为函数参数使用时注意的问题!

#include int main() { void swap(int *p1, int *p2); int a, b; int *pointer1, *pointer2; printf("plea...

C语言指针变量作为函数参数

有读者反馈,不理解字符数组和普通数组的区别,下面笔者作一下解答。 实际上,字符数组和普通数组一样,没有本质区别。 请大家注意数组类型的含义:数据类型指的是数组所包含的元素的类型,而不是数组名的...

C语言指针变量作为函数参数

文章转载地址:http://c.biancheng.net/cpp/html/74.html    侵删 在C语言中,函数的参数不仅可以是整数、小数、字符等具体的数据,还可以是指向它们的指针。用指针...

智能指针变量做函数参数的一个值得注意的地方

作者:朱金灿来源:http://blog.csdn.net/clever101           先考考大家,下面一段程序,会有什么问题:#include #include #include "...

96 C语言指针变量作为函数参数

C学习网:链接->C学习网 C训练网:链接->C训练网 在C语言中,函数的参数不仅可以是整数、小数、字符等具体的数据,还可以是指向它们的指针。用指针变量作函数参数可以将函数外部的地址传递到...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数组名作函数参数和指针变量作函数参数
举报原因:
原因补充:

(最多只允许输入30个字)