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;
}
相关推荐
SuperByteMaster1 小时前
keil 工程 .gitignore配置文件
c语言
老花眼猫5 小时前
编制椭圆旋转绘图函数
c语言·经验分享·青少年编程·课程设计
iCxhust8 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
qeen878 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
handler019 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
热心网友俣先生9 小时前
2026年第二十三届五一数学建模竞赛C题超详细解题思路+各问题可用模型推荐+部分模型结果展示
c语言·开发语言·数学建模
li16709027010 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
Aurorar0rua12 小时前
CS50 x 2024 Notes C - 07
c语言·学习方法
爱编码的小八嘎12 小时前
C语言完美演绎9-15
c语言
weixin_4217252613 小时前
C语言常用字符串函数:长度、比较、拼接和查找
c语言·字符串函数·查找·比较·长度