文章目录  
 1. 提出任务 2. 完成任务 2.1 方法一:通过返回结构体指针来间接返回结果 2.1.1 编写程序,实现功能 2.1.2 运行程序,查看结果 2.2 方法二:通过参数传递数组,并在函数中修改传入的参数 2.2.1 编写程序,实现功能 2.2.2 运行程序,查看结果 3. 实战小结   
 
本次任务要求编写C程序,求出整型数组的最大值和最小值。通过两种方法实现:一是使用结构体指针返回结果,动态分配内存存储最值;二是通过指针参数直接修改传入的变量,避免动态内存分配。两种方法均通过遍历数组更新最值,最终输出结果。任务旨在加深对指针、结构体及函数参数传递的理解,同时掌握高效处理数组最值问题的技巧。 创建FindMaxMin01.c 程序 # include  <stdio.h> # include  <stdlib.h> typedef  struct  Result 
{ 
    int  min; 
    int  max; 
}  Result; 
Result * findMinMax ( int  arr[ ] ,  int  size) 
{ 
    Result * res =  ( Result * ) malloc ( sizeof ( Result) ) ; 
    if  ( size >  0 ) 
    { 
        res-> min =  arr[ 0 ] ; 
        res-> max =  arr[ 0 ] ; 
        for  ( int  i =  1 ;  i <  size;  i++ ) 
        { 
            if  ( arr[ i]  <  res-> min) 
            { 
                res-> min =  arr[ i] ; 
            } 
            if  ( arr[ i]  >  res-> max) 
            { 
                res-> max =  arr[ i] ; 
            } 
        } 
    } 
    return  res; 
} 
int  main ( ) 
{ 
    int  arr[ ]  =  { 5 ,  3 ,  8 ,  1 ,  9 ,  12 ,  67 ,  - 34 ,  100 ,  37 ,  87 } ; 
    int  size =  sizeof ( arr)  /  sizeof ( arr[ 0 ] ) ; 
    Result * result =  findMinMax ( arr,  size) ; 
    printf ( "MinValue: %d\n" ,  result-> min) ; 
    printf ( "MaxValue: %d\n" ,  result-> max) ; 
    free ( result) ;  
    return  0 ; 
} 
代码说明:该代码通过结构体 Result 存储数组的最小值和最大值。函数 findMinMax 遍历数组,更新最值并返回结构体指针。主函数中定义了一个数组,调用 findMinMax 获取最值并输出。代码逻辑清晰,动态分配内存后需手动释放,避免内存泄漏。整体实现了高效的最值查找功能。 运行FindMaxMin.c程序 创建FindMaxMin02.c程序 # include  <stdio.h> void  findMinMax ( int  arr[ ] ,  int  size,  int  * min,  int  * max) 
{ 
    if  ( size >  0 ) 
    { 
        * min =  arr[ 0 ] ; 
        * max =  arr[ 0 ] ; 
        for  ( int  i =  1 ;  i <  size;  i++ ) 
        { 
            if  ( arr[ i]  <  * min) 
            { 
                * min =  arr[ i] ; 
            } 
            if  ( arr[ i]  >  * max) 
            { 
                * max =  arr[ i] ; 
            } 
        } 
    } 
} 
int  main ( ) 
{ 
    int  arr[ ]  =  { 5 ,  3 ,  8 ,  1 ,  9 ,  12 ,  67 ,  - 34 ,  100 ,  37 ,  87 } ; 
    int  size =  sizeof ( arr)  /  sizeof ( arr[ 0 ] ) ; 
    int  min,  max; 
    findMinMax ( arr,  size,  & min,  & max) ; 
    printf ( "MinValue: %d\n" ,  min) ; 
    printf ( "MaxValue: %d\n" ,  max) ; 
    return  0 ; 
} 
代码说明:该代码通过指针参数返回数组的最小值和最大值。函数 findMinMax 遍历数组,更新指针指向的最值。主函数中定义数组,调用 findMinMax 并传入 min 和 max 的地址,最后输出结果。代码避免了动态内存分配,直接通过指针传递结果,简洁高效,适合处理数组最值问题。 运行FindMaxMin02.c程序 在本次实战中,我们通过两种不同的方法实现了对整型数组最大值和最小值的查找。第一种方法通过返回结构体指针来间接返回结果,利用动态内存分配存储最值,代码逻辑清晰,但需注意手动释放内存以避免内存泄漏。第二种方法通过指针参数直接修改传入的参数,避免了动态内存分配,代码更加简洁高效。两种方法各有优劣,第一种适合需要返回多个值的场景,第二种则更适合对性能要求较高的场景。通过本次实战,我加深了对指针、结构体以及函数参数传递的理解,同时也掌握了如何根据需求选择合适的方法来解决问题。