嵌入式day09

数组在函数间传参

全局数组传递方式

复制传递方式

​ 实参为数组的指针,形参为数组名(本质是一个指针变量)

地址传递方式

​ 实参为数组的指针,形参为同类型的指针变量

编写函数,计算一个一维整型数组的所有元素的和

#include<stdio.h>
int array_sum(int data[], int n);
int main(int argc, char *argv[])
{
        int a[] = {1, 3, 7, 9};
        int sum = 0;
        int n;
        n = sizeof(a) / sizeof(int);
        sum = array_sum(a, n);
        printf("%d\n", sum);
        return 0;       
}
int array_sum(int data[], int n)
{
        int ret = 0;
        int i;
        for(i = 0;i < n;i++){
                ret +=data[i];
        }
        return ret;
}

结果:

[外链图片转存失败(img-XfMN5W1n-1564922925163)(/home/kali/Documents/pictures/09/1.png)]

删除字符串中空格

#include<stdio.h>
void del_space(char *str);
int main(int argc, char *argv[])
{
        char s[] = "h  el       h";
        puts(s);
        del_space(s);
        puts(s);
        return 0;
}

void del_space(char *str)
{
        char *s2;
        s2 = str;
        while(*str){
                if(*str ==' '){
                        str++;
                }
                else{
                        *s2 = *str;
                        str++;
                        s2++;
                }
        }
        *s2 = '\0';
}

结果:

[外链图片转存失败(img-P7Wl9VEs-1564922925165)(/home/kali/Documents/pictures/09/2.png)]

指针函数

指针函数是指一个函数的返回值为地址量的函数

一般形式:

<数据类型> * <函数名称>(<参数说明>){
	语句序列;
}

返回值:全局变量的地址/static变量的地址/字符串常量的地址

编写一个指针函数删除字符串空格

#include<stdio.h>
#include<string.h>
char *del_space(char *s);
int main(int argc, char *argv[])
{
        char *r; 
        char str[] = "how are you ";
        r = del_space(str);

        puts(str);
        return 0;    
}

char  *del_space(char *s) 
{
        char *p = s;
        char *r = s;

        while(*s){
                if(*s ==' '){
                        s++;    
                }   
                else{
                        *p = *s; 
                        s++;
                        p++;
                }   
        }           
        *p = '\0';
        return r;  
}

结果:

[外链图片转存失败(img-HKAzsDQh-1564922925167)(/home/kali/Documents/pictures/09/3.png)]

编写一个指针函数,实现字符串连接

#include<stdio.h>
#include<string.h>
char *pstrcat(char *dest, const char *src);
int main(int argc, char *argv[])
{
        char dest[30] = "ghhhhhb";
        char src[] = "ljghg";
        strcat(dest, src);
        puts(strcat(dest, src));
        puts(dest);

        return 0;
}

char *pstrcat(char *dest, const char *src)
{
        char *r = dest;
        while(*dest){
                dest++;
        }
        while(*src){
                *dest = *src;
                dest++;
                src++;
        }
        *dest = '\0';
        return r;
}

结果:

[外链图片转存失败(img-5oVGh6JC-1564922925168)(/home/kali/Documents/pictures/09/4.png)]

用函数指针来编写将一个整形转换成字符串

#include<stdio.h>
#include<string.h>
char *itoa(int n);
int main(int argc, char *argv[])
{
        int n;
        char *s;
        printf("input:");
        scanf("%d", &n);
        s = itoa(n);
        puts(s);

        return 0;       
}
char *itoa(int n)
{
        int r, i = 0, j;
        static char p[30];
        while(n){
                r = n % 10;
                n /= 10;
                p[i] = r + '0';
                i++;
        }       
        p[i] = '\0';
        j = i-1;
        i = 0;
        while(i < j){
                r = p[i];
                p[i] = p[j];
                p[j] = r;
                i++;
                j--;

        }
        return p;
}

结果:

[外链图片转存失败(img-IrLw9qCQ-1564922925169)(/home/kali/Documents/pictures/09/5.png)]

递归函数

递归函数是指一个函数的函数体中直接调用了该函数自身

递归函数调用的执行过程分为两个阶段:

​ 递归阶段:从原问题出发,按递归公式递推从未知到已知,最终达到递归终止条件

​ 回归阶段:按递归终止条件求出结果,逆向逐步代入递归公式,回归原问题求解

编写一个递归函数n的阶乘

#include<stdio.h>
int fun(int n);
int main(int argc, char *argv[])
{
        int n;
        int s=0;

        printf("Please input n:");
        scanf("%d", &n);
        s = fun(n);
        printf("%d\n", s);
        return 0;
}
int fun(int n)
{
        if( n==0 || n==1){
                return 1;
        }
        return n * fun(n-1);
}       

结果:

[外链图片转存失败(img-knLMl2zW-1564922925170)(/home/kali/Documents/pictures/09/6.png)]

写一个递归函数,计算斐波拉契数列

#include<stdio.h>
int fun(int n);
int main(int argc, char *argv[])
{
        int n = 0;
        while(n <= 10){
                printf("%d ", fun(n));
                n++;
        }
        printf("\n");
        return 0;
}
int fun(int n)
{
        if( n==0 || n==1){
                return 1;
        }
        return fun(n-2) + fun(n-1);
}

结果:

[外链图片转存失败(img-vhlaSHX9-1564922925171)(/home/kali/Documents/pictures/09/7.png)]

函数指针

函数指针用来存放函数的地址,这个地址是一个函数的入口地址

函数名代表了函数的入口地址

函数指针变变量说明的一般形式如下:

<数据类型> (*<函数指针名称>) (<参数说明列表>);

<数据类型>是函数指针指向的函数的返回值类型

<参数说明列表>应该与函数指针所指向函数的形参说明保持一致

(*<函数指针名称>)中,*说明为指针()不可缺省,表明为函数的指针

函数指针数组

函数指针数组是一个保存若干个函数名的数组

一般形式:

<数据类型> (*<函数指针数组名称>) [<大小>])(<参数说明列表>)

排序函数

ainclude<stdio.h>
int compare(const void *, const void *);
int main(int argc, char *argv[])
{
        int s[] = {89, 23, 4, 7, 23, 3};
        int n, i;
        n = sizeof(s) / sizeof(int);
        qsort(s, n, sizeof(int), compare);
        for(i=0;i<n;i++)
                printf("%d ", s[i]);
        puts("");

        return 0;
}
int compare(const void *p, const void *q)
{       
        return (*(int *)p - *(int *)q);
}

结果:

[外链图片转存失败(img-YG1mAfmy-1564922925172)(/home/kali/Documents/pictures/09/8.png)]

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值