文章目录
1. 提出任务 2. 完成任务 2.1 方法一:通过返回结构体指针来间接返回结果 2.1.1 编写程序,实现功能 2.1.2 运行程序,查看结果
2.2 方法二:通过参数传递数组,并在函数中修改传入的参数 2.2.1 编写程序,实现功能 2.2.2 运行程序,查看结果
3. 实战小结
1. 提出任务
本次任务要求编写C程序,求出整型数组的最大值和最小值。通过两种方法实现:一是使用结构体指针返回结果,动态分配内存存储最值;二是通过指针参数直接修改传入的变量,避免动态内存分配。两种方法均通过遍历数组更新最值,最终输出结果。任务旨在加深对指针、结构体及函数参数传递的理解,同时掌握高效处理数组最值问题的技巧。
2. 完成任务
2.1 方法一:通过返回结构体指针来间接返回结果
2.1.1 编写程序,实现功能
创建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
获取最值并输出。代码逻辑清晰,动态分配内存后需手动释放,避免内存泄漏。整体实现了高效的最值查找功能。
2.1.2 运行程序,查看结果
运行FindMaxMin.c
程序
2.2 方法二:通过参数传递数组,并在函数中修改传入的参数
2.2.1 编写程序,实现功能
创建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
的地址,最后输出结果。代码避免了动态内存分配,直接通过指针传递结果,简洁高效,适合处理数组最值问题。
2.2.2 运行程序,查看结果
运行FindMaxMin02.c
程序
3. 实战小结
在本次实战中,我们通过两种不同的方法实现了对整型数组最大值和最小值的查找。第一种方法通过返回结构体指针来间接返回结果,利用动态内存分配存储最值,代码逻辑清晰,但需注意手动释放内存以避免内存泄漏。第二种方法通过指针参数直接修改传入的参数,避免了动态内存分配,代码更加简洁高效。两种方法各有优劣,第一种适合需要返回多个值的场景,第二种则更适合对性能要求较高的场景。通过本次实战,我加深了对指针、结构体以及函数参数传递的理解,同时也掌握了如何根据需求选择合适的方法来解决问题。