C Programming Language | Manipulating arrays in functions

c 复制代码
#include <stdio.h>
/*
1.编写一个函数,打印传入的数组中的所有元素。
	 
*/
void printArr(int arr[],int len){
		for(int i=0;i<len;i++){
			printf("%d\n",arr[i]);
		}
}

int main(){
	//int 类型的数组
	int arr1[5]={1,2,3,4,5};
	int arr2[3]={7,8,9};

	printArr(arr1,5); 
	printArr(arr2,3); 
	return 0;
} 
//函数中操作数组 
//printf("在函数中传入数组");

改变原地址

c 复制代码
void funArr(int arr[]){
    arr[0]=100;
    arr[1]=200;
}

int main(){
    // int 类型的数组
    int arr[]={1,2};
    printf("%d %d\n", arr[0], arr[1]);
    funArr(arr);
    printf("%d %d\n", arr[0], arr[1]);
}

局部变量不改变

c 复制代码
void f(int m){
    m += 10;
}

int main(){
    int m = 1;
    printf("m=%d\n", m); // 1
    f(m);
    printf("m=%d", m); // 1
}

任务1: 定义一个函数,它的参数是int数组,它的返回值是数组中的所有元素的和。 int getArrSum(int arr[], int len){

}

c 复制代码
int getArrSum(int arr[], int len){
    int sum = 0;
    for(int i = 0; i<len; i++){
        sum += arr[i];
    }
    return sum;
}

int main(){
    int arr[3] = {1,2,3};
    printf("%d", getArrSum(arr, 3));
}

任务2: 定义一个函数,它的参数是int数组,它的返回值是数组中的所有元素的最大值。 int getArrMax(int arr[], int len){ }

c 复制代码
//任务2:获取数组中的最大值
#include <stdio.h>
int getArrMax(int arr[], int len) {
    // 处理数组长度为0的异常情况
    if (len <= 0) {
        printf("数组长度无效!\n");
        return 0; // 或根据需求返回其他标识值
    }
    // 假设第一个元素为最大值
    int max = arr[0];
    // 遍历数组,从第二个元素开始比较
    for (int i = 1; i < len; i++) {
        if (arr[i] > max) {
            max = arr[i]; // 更新最大值
        }
    }
    return max;
}

// 测试函数
int main() {
    // 测试用例1:普通数组
    int arr1[5] = {3, 7, 2, 9, 5};
    printf("数组1的最大值:%d\n", getArrMax(arr1, 5)); // 输出9

    // 测试用例2:包含负数的数组
    int arr2[4] = {-5, -2, -8, -1};
    printf("数组2的最大值:%d\n", getArrMax(arr2, 4)); // 输出-1

    // 测试用例3:单元素数组
    int arr3[1] = {10};
    printf("数组3的最大值:%d\n", getArrMax(arr3, 1)); // 输出10

    return 0;
}

任务3: 定义一个函数,它的参数是int数组,和要查找的值。如果在这个数组中,能找到,则返回第一个找到的值的下标; 如果找不到,则返回-1 int findArrValue(int arr[], int len, int val) { }

c 复制代码
#include <stdio.h>

// 任务3:查找数组中目标值的第一个下标,未找到返回-1
int findArrValue(int arr[], int len, int val) {
    // 处理数组长度无效的情况
    if (len <= 0) {
        printf("数组长度无效!\n");
        return -1;
    }
    // 遍历数组,逐个匹配目标值
    for (int i = 0; i < len; i++) {
        if (arr[i] == val) {
            return i; // 找到目标值,返回当前下标
        }
    }
    // 遍历结束未找到,返回-1
    return -1;
}

// 测试函数
int main() {
    // 测试用例1:目标值存在且出现多次
    int arr1[6] = {3, 7, 2, 7, 5, 9};
    int index1 = findArrValue(arr1, 6, 7);
    if (index1 != -1) {
        printf("目标值7的第一个下标:%d\n", index1); // 输出1
    } else {
        printf("未找到目标值7\n");
    }

    // 测试用例2:目标值不存在
    int index2 = findArrValue(arr1, 6, 10);
    if (index2 != -1) {
        printf("目标值10的第一个下标:%d\n", index2);
    } else {
        printf("未找到目标值10\n"); // 输出该语句
    }

    // 测试用例3:单元素数组且匹配
    int arr2[1] = {5};
    int index3 = findArrValue(arr2, 1, 5);
    if (index3 != -1) {
        printf("目标值5的第一个下标:%d\n", index3); // 输出0
    } else {
        printf("未找到目标值5\n");
    }

    // 测试用例4:空数组(长度为0)
    int arr3[0];
    int index4 = findArrValue(arr3, 0, 2);
    if (index4 != -1) {
        printf("目标值2的第一个下标:%d\n", index4);
    } else {
        printf("未找到目标值2(数组为空)\n"); // 输出该语句
    }

    return 0;
}
相关推荐
Trouvaille ~2 小时前
【Linux】库制作与原理(三):动态链接与加载机制
linux·c语言·汇编·got·动静态库·动态链接·plt
一个不知名程序员www2 小时前
算法学习入门---C/C++输入输出
c语言·c++
superman超哥4 小时前
仓颉性能瓶颈定位方法深度解析
c语言·开发语言·c++·python·仓颉
leaves falling5 小时前
c语言-static和extern
c语言·开发语言
黎雁·泠崖5 小时前
C 语言的内存函数:memcpy/memmove/memset/memcmp 精讲(含模拟实现)
c语言·开发语言
HUST5 小时前
C 语言 第八讲:VS实用调试技巧
运维·c语言·开发语言·数据结构·算法·c#
Yupureki6 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-二分算法
c语言·开发语言·数据结构·c++·算法·visual studio
liujing102329296 小时前
stm32 开发的 c_cpp_properties.json 配置
c语言·stm32·嵌入式硬件
胖咕噜的稞达鸭6 小时前
【C语言进阶】死磕指针:从内存原理到指针数组的深度解析
c语言·开发语言·网络