当前位置: 首页 > news >正文

实验四 数组和函数

  • 实验名称

实验四 数组和函数

  • 实验目的

(1)掌握一维、二维数组以及字符数组的定义、元素引用和编程方法。

(2)掌握字符串常用程序的设计方法。

(3)掌握函数定义和调用的方法,以及函数参数传递的方式。

(4)理解变量的作用域及生存期。

  • 实验题目
  1. 编写程序计算Fibonacci数列的前40项。(要求每行输出4个数)
  2. 从键盘上输入一个3×4的整数矩阵,找出其中最大值和最小值,记录它们的行号和列号并输出。
  3. 编写程序将2个字符串连接起来(不使用strcat函数)并输出。
  4. 编程实现一个具有+,-,×,÷,%运算功能的简单计算器。(通过函数实现)
  5. 任意输入2个整数,编写2个函数分别求这2个整数的最大公约数和最小公倍数,结果在主函数中输出。
  • 实验环境

硬件:个人电脑;软件:Visual C++ 6.0

  • 实验代码及结果(程序运行结果请以截屏图给出)
  1. 源程序代码:

#include <stdio.h>

int main()

{

    int fibonacci[40];

    fibonacci[0] = 0;

    fibonacci[1] = 1;

    for (int i = 2; i < 40; i++)

        fibonacci[i] = fibonacci[i - 1] + fibonacci[i - 2];

    for (int i = 0; i < 40; i++)

    {

        printf("%d ", fibonacci[i]);

        if ((i + 1) % 4 == 0) // 使用 (i + 1) % 4 来判断是否是每行的最后一个数字

            printf("\n");

    }

    return 0;

}

运行结果为:

  1. 源程序代码:

#include <stdio.h>

#include <limits.h>

int main()

{

    int matrix[3][4];

    int max_value = INT_MIN, min_value = INT_MAX;

    int max_row, max_col, min_row, min_col;

    printf("请输入一个3x4的整数矩阵:\n");

    for (int i = 0; i < 3; i++)

    {

        for (int j = 0; j < 4; j++)

        {

            scanf("%d", &matrix[i][j]);

            // 更新最大值和最小值及其位置

            if (matrix[i][j] > max_value)

            {

                max_value = matrix[i][j];

                max_row = i;

                max_col = j;

            }

            if (matrix[i][j] < min_value)

            {

                min_value = matrix[i][j];

                min_row = i;

                min_col = j;

            }

        }

    }

    printf("最大值:%d,位置:(%d, %d)\n", max_value, max_row, max_col);

    printf("最小值:%d,位置:(%d, %d)\n", min_value, min_row, min_col);

    return 0;

}

运行结果为:

  1. 源程序代码:

#include <stdio.h>

int main()

{

    char str1[100] = "Hello, ";

    char str2[] = "World!";

    int i = 0, j = 0;

    // 找到str1的末尾

    while (str1[i] != '\0')

        i++;

    // 将str2的字符逐个复制到str1的末尾

    while (str2[j] != '\0')

    {

        str1[i] = str2[j];

        i++;

        j++;

    }

    // 在str1的末尾添加字符串结束符'\0'

    str1[i] = '\0';

    // 输出连接后的字符串

    printf("%s\n", str1);

    return 0;

}

运行结果为:

  1. 源程序代码:

#include <stdio.h>

double add(double a, double b)

{

    return a + b;

}

double subtract(double a, double b)

{

    return a - b;

}

double multiply(double a, double b)

{

    return a * b;

}

double divide(double a, double b)

{

    return a / b;

}

int modulus(int a, int b)

{

    return a % b;

}

// 主函数

int main()

{

    char operator;

    double num1, num2;

    double result;

    printf("请输入一个算式:\n");

    scanf("%lf %c %lf", &num1, &operator, &num2);

    // 根据运算符执行相应的运算

    switch (operator)

    {

        case '+':

            result = add(num1, num2);

            break;

        case '-':

            result = subtract(num1, num2);

            break;

        case '*':

            result = multiply(num1, num2);

            break;

        case '/':

            result = divide(num1, num2);

            break;

        case '%':

            // 执行取模运算

            result = modulus(num1, num2);

            break;

        default:

            printf("错误:无效的运算符。\n");

            return 1; // 返回非零值表示程序异常终止

    }

        // 输出其他运算的结果

        printf("结果:%.2lf %c %.2lf = %.2lf\n", num1, operator, num2, result);

    return 0;

}

运行结果为:

  1. 源程序代码:

#include <stdio.h>

// 求最大公约数的递归函数(辗转相除法)

int gcd(int a, int b)

{

    if (b == 0)

        return a;

    else

        return gcd(b, a % b);

}

// 求最小公倍数的函数(利用GCD)

int lcm(int a, int b, int gcd_result)

{

    return (a * b) / gcd_result;

}

// 主函数

int main()

{

    int num1, num2;

    int gcd_result, lcm_result;

    // 输入两个整数

    printf("请输入两个整数:\n");

    scanf("%d %d", &num1, &num2);

    // 计算最大公约数(使用递归辗转相除法)

    gcd_result = gcd(num1, num2);

    // 计算最小公倍数

    lcm_result = lcm(num1, num2, gcd_result);

    printf("最大公约数:%d\n", gcd_result);

    printf("最小公倍数:%d\n", lcm_result);

    return 0;

}

运行结果为:

六、实验心得(请对每个实验题目编程及调试运行中遇到的问题及解决方案进行简单总结)

相关文章:

实验四 数组和函数

实验名称 实验四 数组和函数 实验目的 &#xff08;1&#xff09;掌握一维、二维数组以及字符数组的定义、元素引用和编程方法。 &#xff08;2&#xff09;掌握字符串常用程序的设计方法。 &#xff08;3&#xff09;掌握函数定义和调用的方法&#xff0c;以及函数参数传…...

基于安卓14 的ANR dump信息原理

首先以 service 处理超时逻辑来分析 1&#xff09;service timeout调用到anr 的逻辑&#xff1a; /frameworks/base/services/core/java/com/android/server/am/ActiveServices.java 5827 void scheduleServiceTimeoutLocked(ProcessRecord proc) { 5828 if (…...

C++ volatile(八股总结)

答&#xff1a;跟编译器优化有关&#xff0c;告诉编译器每次操作该变量时一定要从内存中真正取出&#xff0c;而不是使用已经存在寄存器中的备份。 volatile是一个类型限定符&#xff0c;用来告诉编译器&#xff0c;某个变量的值可能在任何时刻发生变化&#xff0c;因此&#…...

SQL从入门到实战

学前须知 sqlzoo数据介绍 world nobel covid ge game、goal、eteam teacher、dept movie、casting、actor 基础语句 select&from SELECT from WORLD Tutorial - SQLZoo 基础查询select单列&多列&所有列&别名应用 例题一 SELECT name, continent, population …...

Redis源码阅读-源码阅读方式

Redis源码下载 首先通过地址&#xff08;https://github.com/redis/redis&#xff09;下载redis的源码。redis的源码版本&#xff0c;这里可以选择合适的查看&#xff0c;这里选择的是redis 5.x版本的源码。 Redis源码查看方式 这里可以选择合适的C开发工具&#xff0c;打开…...

若依框架简介

若依&#xff08;RuoYi&#xff09;框架是一个基于Java语言的后台管理系统快速开发框架&#xff0c;它结合了多种前端和后端技术&#xff0c;提供了高效的开发工具。以下是对若依框架的详细解析&#xff1a; 一、技术架构 后端&#xff1a;若依框架后端采用了Spring Boot、My…...

MOE怎样划分不同专家:K-Means聚类算法来实现将神经元特征聚类划分

MOE怎样划分不同专家:K-Means聚类算法来实现将神经元特征聚类划分 目录 MOE怎样划分不同专家:K-Means聚类算法来实现将神经元特征聚类划分MOE划分不同专家的方法K-Means聚类算法来实现将神经元特征聚类划分成不同专家(行或者列聚类)举例说明怎么聚类,最后神经网络怎么保存M…...

为 CentOS7 虚拟机添加第二块网卡

为 CentOS7 虚拟机添加第二块网卡 目录 为 CentOS7 虚拟机添加第二块网卡一、在虚拟中添加网卡二、网卡配置1、查看新增的网卡信息2、创建网卡配置文件 一、在虚拟中添加网卡 1、右击虚拟机&#xff0c;在弹出的菜单中选择【设置】&#xff0c;弹出如下图所示的【虚拟机设置】…...

30天开发操作系统 第 12 天 -- 定时器

前言 定时器(Timer)对于操作系统非常重要。它在原理上却很简单&#xff0c;只是每隔一段时间(比如0.01秒)就发送一个中断信号给CPU。幸亏有了定时器&#xff0c;CPU才不用辛苦地去计量时间。……如果没有定时器会怎么样呢?让我们想象一下吧。 假如CPU看不到定时器而仍想计量时…...

雷达的分类

雷达是一种利用电磁波进行探测和定位的设备&#xff0c;其分类方式多种多样&#xff0c;以下是按照不同标准对雷达进行的分类&#xff1a; 一、按功能分类 警戒雷达&#xff1a;用于搜索、监视和识别空中、海面或地面的目标&#xff0c;为防御系统提供早期预警。引导雷达&…...

Ubuntu桌面管理环境: GDM3,KDM,LightDM

介绍 Ubuntu是一个广受欢迎的Linux操作系统&#xff0c;拥有强大而多样化的桌面管理环境。其中三个常用的桌面管理环境是GDM3&#xff0c;KDM和LightDM。本篇博客将介绍这三个桌面管理环境的特点和功能。 GDM3 (GNOME Display Manager) GDM3是默认的桌面管理环境&#xff0c…...

使用Llama 3.1创建合成数据集以调优你的大型语言模型

使用Llama 3.1创建合成数据集以调优你的大型语言模型 在数据驱动的人工智能领域&#xff0c;数据是核心资产。开发高质量数据集既复杂又昂贵&#xff0c;因此很多实验室和开发者选择使用合成数据集。本文将介绍如何利用大型语言模型Llama 3.1 405B创建合成数据集&#xff0c;并…...

js可不使用document直接根据id获取id元素

今天在用原生js写demo的时候发现一个有意思的小现象&#xff0c;那就是可以直接根据元素的id去获取对应的元素。 起先是我定义了四个btn&#xff0c;每个btn都是根据getElementById来获取元素&#xff0c;然后给元素绑定事件&#xff0c;在调试的时候都挺好&#xff0c;到了后…...

【竞技宝】CS2:HLTV2024职业选手排名TOP8-broky

北京时间2025年1月7日,HLTV年度选手排名正在持续公布中,今日凌晨正式公布了今年的TOP8为FAZE战队的broky。 选手简介 broky是一位来自拉脱维亚的职业CS选手,现年23岁。2018年7月,broky获得了FPL资格,连续几季在榜上前5。他的首次赛场留名是跟随拉脱维亚本土战队Wolsung出征BES…...

Apache Paimon-实时数据湖

一、Apache Paimon是什么? Flink社区希望能够将 Flink 的 Streaming 实时计算能力和 Lakehouse 新架构优势进一步结合&#xff0c;推出新一代的 Streaming Lakehouse 技术&#xff0c;促进数据在数据湖上真正实时流动起来&#xff0c;并为用户提供实时离线一体化的开发体验。 …...

hpm使用笔记————使用usb作为从机接收来自上位机的数据然后通过spi主机发送给spi从机

历程整合 环境要求任务需求任务实现代码实现任务测试功能测试 结束 环境 hpm_sdk v 1.7.0ses v8.10 要求 例程demo USB-CDC 作为从机接收&#xff0c;然后把接收到的数据转发给SPI&#xff0c;SPI传输出去 任务需求 USB使用cherry协议栈进行开发 作为device设备&#xff08;…...

数据结构(查找算法)

1. 查找的概念 在一堆数据中&#xff0c;找到我们想要的那个数据&#xff0c;就是查找&#xff0c;也称为搜索&#xff0c;很容易想到&#xff0c;查找算法的优劣&#xff0c;取决于两个因素&#xff1a; 数据本身存储的特点查找算法本身的特点 比如&#xff0c;如果数据存储…...

private前端常见算法

1.数组 合并两个有序数组&#xff08;简单-5&#xff09; https://leetcode.cn/problems/merge-sorted-array/description/?envTypestudy-plan-v2&envIdtop-interview-150 移除元素&#xff08;简单-4&#xff09; https://leetcode.cn/problems/remove-element/descr…...

Go语言之十条命令(The Ten Commands of Go Language)

Go语言之十条命令 Go语言简介 Go语言&#xff08;又称Golang&#xff09;‌是由Google开发的一种开源编程语言&#xff0c;首次公开发布于2009年。Go语言旨在提供简洁、高效、可靠的软件开发解决方案&#xff0c;特别强调并发编程和系统编程‌。 Go语言的基本特征 ‌静态强类…...

Residency 与 Internship 的区别及用法解析

Residency 与 Internship 的区别及用法解析 在英文中&#xff0c;“residency” 和 “internship” 都与职业培训相关&#xff0c;但它们的使用场景和具体含义存在显著差异。本文将详细解析这两个词的区别&#xff0c;以及它们在不同语境下的应用。 Residency 的定义及使用场景…...

成品电池综合测试仪:电子设备性能与安全的守护者|鑫达能

在现代科技和工业领域&#xff0c;电池作为能量储存和转换的关键组件&#xff0c;其性能的稳定性和可靠性至关重要。为了确保电池在各种应用场景中都能发挥最佳性能&#xff0c;成品电池综合测试仪应运而生。这一设备不仅能够对电池的各项性能指标进行全面、准确的检测&#xf…...

Taro地图组件和小程序定位

在 Taro 中使用腾讯地图 1.首先在项目配置文件 project.config.json 中添加权限&#xff1a; {"permission": {"scope.userLocation": {"desc": "你的位置信息将用于小程序位置接口的效果展示"}} }2.在 app.config.ts 中配置&#x…...

深入了解 SSL/TLS 协议及其工作原理

深入了解 SSL/TLS 协议及其工作原理 一. 什么是 SSL/TLS?二. SSL/TLS 握手过程三. SSL/TLS 数据加密与传输四. 总结 点个免费的赞和关注&#xff0c;有错误的地方请指出&#xff0c;看个人主页有惊喜。 作者&#xff1a;神的孩子都在歌唱 一. 什么是 SSL/TLS? 安全套接层&am…...

【计算机操作系统:二、操作系统的结构和硬件支持】

第2章 操作系统的结构和硬件支持 2.1 操作系统虚拟机 操作系统虚拟机是一种通过软件技术对硬件资源进行抽象和虚拟化的机制&#xff0c;使用户能够以逻辑方式访问和使用计算机资源。 定义与概念&#xff1a; 虚拟机是操作系统虚拟化技术的核心产物&#xff0c;通过模拟硬件资…...

51单片机——步进电机模块

直流电机没有正负之分&#xff0c;在两端加上直流电就能工作 P1.0-P1.3都可以控制电机&#xff0c;例如&#xff1a;使用P1.0&#xff0c;则需要把线接在J47的1&#xff08;VCC&#xff09;和2&#xff08;OUT1&#xff09;上 1、直流电机实验 要实现的功能是&#xff1a;直…...

当算法遇到线性代数(四):奇异值分解(SVD)

SVD分解的理论与应用 线性代数系列相关文章&#xff08;置顶&#xff09; 1.当算法遇到线性代数&#xff08;一&#xff09;&#xff1a;二次型和矩阵正定的意义 2.当算法遇到线性代数&#xff08;二&#xff09;&#xff1a;矩阵特征值的意义 3.当算法遇到线性代数&#xff0…...

SASS 简化代码开发的基本方法

概要 本文以一个按钮开发的实例&#xff0c;介绍如何使用SASS来简化CSS代码开发的。 代码和实现 我们希望通过CSS开发下面的代码样式&#xff0c;从样式来看&#xff0c;每个按钮的基本样式相同&#xff0c;就是颜色不同。 如果按照传统的方式开发&#xff0c;需要开发btn &…...

40.TryParse尝试转化为int类型 C#例子

也许这个时候学有点晚&#xff0c;但是不管怎样都学了 尝试转化&#xff0c;不能转化就返回bool类型的假 它会直接给括号里面的int类型赋值 代码&#xff1a; using System; using System.Timers; public class Program {static void Main(){int a;bool i;while (true){Get…...

【微服务】2、网关

Spring Cloud微服务网关技术介绍 单体项目拆分微服务后的问题 服务地址问题&#xff1a;单体项目端口固定&#xff08;如黑马商城为8080&#xff09;&#xff0c;拆分微服务后端口各异&#xff08;如购物车808、商品8081、支付8086等&#xff09;且可能变化&#xff0c;前端难…...

红队-shell编程篇(上)

声明 通过学习 泷羽sec的个人空间-泷羽sec个人主页-哔哩哔哩视频,做出的文章如涉及侵权马上删除文章 笔记的只是方便各位师傅学习知识,以下网站只涉及学习内容,其他的都与本人无关,切莫逾越法律红线,否则后果自负 一、建立Shell文件 1. Shell简介 Shell是一种命令行界面&am…...