站長資訊網
        最全最豐富的資訊網站

        《C語言實驗指導》實驗八 函數

        實驗八 函數

        【目的與要求】

        1.掌握C語言函數的定義方法、函數的聲明及函數的調用方法。

        2.了解主調函數和被調函數之間的參數傳遞方式。

        【上機內容】

        【一般示例】

        【例1】寫一個判斷素數的函數,在主函數輸入一個整數,輸出是否素數的信息。

        源程序如下:

        mian()

        {

        int number;

        printf(“請輸入一個正整數:n”);

        scanf(“%d”,&number);

        if (prime(number))

        printf(“n %d是素數.”,number);

        else

        printf(“n %d不是素數.”,number);

        }

        int prime(number) /*此函數用于判別素數*/

        int number;

        {

        int flag=1,n;

        for(n=2;n<number/2&&flag==1;n++)

        if (number%n==0)

        flag=0;

        return(flag);

        }

        判斷素數的算法,我們在以前學習循環的時候已經學過了,在這里只是把這個算法用函數的形式表示出來。這里我們要注意函數的定義、聲明的方法和格式。

        【例2】寫一函數,是給定的一個二位數組(4×4)轉置,即行列互換。

        源程序如下:

        /*矩陣的轉置*/

        #define N 4

        int array[N][N];

        convert(array)

        int array[4][4];

        {

        int i,j,t;

        for (i=0;i<N;i++)

        for (j=i+1;j<N;j++)

        {

        t=array[i][j]; array[i][j]=array[j][i]; array[j][i]=t;

        }

        }

        main()

        {

        int i,j;

        printf(“輸入數組元素:n”);

        for (i=0;i<N;i++)

        for (j=0;j<N;j++)

        scanf(“%d”,&array[i][j]);

        printf(“n數組是:n”);

        for (i=0;i<N;i++)

        {

        for (j=0;j<N;j++)

        printf(“%5d”,array[i][j]);

        printf(“n”);

        }

        conver(array);

        printf(“轉置數組是:n”);

        for (i=0;i<N;i++)

        {

        for (j=0;j<N;j++)

        printf(“%5d”,array[i][j]);

        printf(“n”);

        }

        }

        本例題用數組作為函數參數,大家要注意數組作為函數參數時的用法。

        【典型示例】

        【例1】寫兩個函數,分別求兩個正數的最大公約數和最小公倍數,用主函數調用這兩個函數并輸出結果。兩個正數由鍵盤輸入。

        源程序如下:

        #include “stdio.h”

        hcf(u,v)

        int u,v;

        {

        int a,b,t,r;

        if(u>v)

        {

        t=u; u=v; v=t;

        }

        a=u; b=v;

        while((r=b%a)!=0)

        {

        b=a; a=r;

        }

        return(a);

        }

        lcd(u,v,h)

        int u,v,h;

        {

        return(u*v/h);

        }

        main()

        {

        int u,v,h,l;

        scanf(“%d,%d”,&u,&v);

        h=hcf(u,v);

        printf(“H.C.F=%dn”,h);

        l=lcd(u,v,h);

        printf(“L.C.D=%dn”,l);

        }

        這是一個十分典型的算法,同學們一定要認真分析、學習。

        【例2】寫一函數,用“起泡法”對輸入的10個字符按由小到大順序排序。

        源程序如下:

        /*起泡法排序*/

        #define N 10

        char str[N];

        main()

        {

        int i,flag;

        for (flag=1; flag = =1;)

        {

        printf(“n輸入字符串,長度為10:n”);

        scanf(“%s”,&str);

        if (strlen(str)>N)

        printf(“超過長度,請重輸!”);

        else

        flag = 0;

        }

        sort(str);

        printf(“n排序結果:”):

        for (i=0;i<N;i++)

        printf(“%c”,str[i]);

        }

        sort(str)

        char str[N];

        {

        int i,j;

        char t;

        for (j=1;j<N;j++)

        for (i=0;(i<N-j)&&(str[i]!=’

        主站蜘蛛池模板: 精品亚洲成a人片在线观看少妇| 国产精品视频二区不卡| 亚洲爆乳无码精品AAA片蜜桃 | 亚洲av午夜精品一区二区三区 | 日韩一区精品视频一区二区| 精品国产热久久久福利| 久久精品国产91久久综合麻豆自制| 中文字幕精品亚洲无线码一区应用| 国产高清精品在线| 久久99热精品| 国产精品视频免费| 国产产无码乱码精品久久鸭| 亚洲一区精品无码| 亚洲欧美日韩国产一区二区三区精品| 国产成人精品免高潮在线观看| 精品麻豆丝袜高跟鞋AV| 狼色精品人妻在线视频| 亚洲av永久无码精品古装片| 亚洲?V无码乱码国产精品| 久久激情亚洲精品无码?V| 国产精品内射视频免费| wwwvr高清亚洲精品二区| 777欧美午夜精品影院| 久久99国产精品一区二区| 精品国产第1页| 国产一区二区精品久久| 国产精品国产精品国产专区不卡 | 精品国产粉嫩内射白浆内射双马尾| 日韩欧精品无码视频无删节| 在线精品亚洲| 最新国产成人精品2024| 亚洲日韩国产精品第一页一区| 亚洲国产人成精品| 中文字幕亚洲精品无码| 亚洲国产精品一区二区成人片国内| 亚洲热线99精品视频| 欧美肥屁VIDEOSSEX精品| 精品一区二区三区在线观看视频| 久久九九精品99国产精品| 精品国产乱码久久久久久1区2区| 国产在线精品免费aaa片|