C语言基础入门案例(3)

目录

第一题:一维数组的最大值和最小值求解

第二题:求一维数组中的第二大的数

第三题:计算5个整数的平均值

第四题:查找整数在数组中的索引位置

第五题:统计字符串中数字字符的个数


第一题:一维数组的最大值和最小值求解

问题描述:
编写一个C语言程序,该程序应定义两个函数maxmin,用于分别求取给定一维数组中的最大值和最小值。主函数main中应声明一个整数数组,并计算该数组的长度。然后,调用maxmin函数分别获取数组的最大值和最小值,并将结果输出到控制台。

要求:

  1. max函数应接收一个整数数组的指针和数组的长度作为参数,返回数组中的最大值。
  2. min函数应接收一个整数数组的指针和数组的长度作为参数,返回数组中的最小值。
  3. main函数中,应定义并初始化一个整数数组,然后计算数组的长度。
  4. 调用maxmin函数,并将返回的最大值和最小值通过printf函数输出到控制台。

示例:
给定数组{1, 2, 3, 55, 34, 12, 98, 5, 7, 8}

程序应输出:

最大值 = 98 
最小值 = 1

注意:在实际编程中,请确保数组的大小足够大,以防止数组越界访问。此外,在调用maxmin函数时,应传递数组的地址(即使用&操作符)和数组的长度。

示例代码:

#include <stdio.h>// 最大值
int max(int *arr, int len)
{int max = arr[0]; // 最大值  定义一个临时变量保存比较后的结果for (int i = 0; i < len; i++){// 最大值if (arr[i] > max){max = arr[i];}}return max;
}
// 最小值
int min(int *arr, int len)
{int min = arr[0]; // 最小值  定义一个临时变量保存比较后的结果for (int i = 0; i < len; i++){// 最小值if (arr[i] < min){min = arr[i];}}return min;
}
int main()
{// 求一维数组的最大值和最小值。// 1. 定义数组int arr[10] = {1, 2, 3, 55, 34, 12, 98, 5, 7, 8};// 2. 数组长度int len = sizeof(arr) / sizeof(arr[0]);printf("最大值 = %d\n最小值 = %d", max(&arr, len), min(&arr, len));return 0;
}

运行结果:

第二题:求一维数组中的第二大的数

问题描述:
编写一个C语言程序,该程序应定义一个整数数组,并求出该数组中的第二大的数。要求程序首先找到数组中的最大值,并随后在剩余的元素中找到次大值。最后,将次大值输出到控制台。

要求:

  1. 数组应至少包含两个元素,以确保可以找到第二大的数。
  2. 程序中应包含对数组长度的计算,以便进行循环遍历。
  3. 在遍历数组时,首先找到最大值,并记录其位置(如果需要)。
  4. 随后,再次遍历数组,但跳过最大值,找到次大值。
  5. 最后,使用printf函数输出次大值。

示例:
给定数组{1, 2, 3, 55, 34, 12, 56, 98, 7, 8}

输出:

第二大的值 = 56

注意:如果数组中存在多个相同的最大值,那么次大值应为除去这些最大值后的最大元素。此外,如果数组只有一个元素或所有元素都相同,则程序应能够处理这种情况,并给出适当的提示或输出。

示例代码:

#include <stdio.h>int main()
{// 2.求一个数组中第二大的数。// 1. 定义数组int arr[10] = {1, 2, 3, 55, 34, 12,56, 98, 7, 8};// 2. 定义一个临时变量保存最大值int max = arr[0];// 定义变量保存第二大的值int secondMax;// 3. 长度int len = sizeof(arr) / sizeof(arr[0]);// 4. for循环for (int i = 0; i < len; i++){if (arr[i] > max){secondMax = max;max = arr[i];}else{if (arr[i] > secondMax){secondMax = arr[i];}}}printf("第二大的值 = %d\n", secondMax);return 0;
}

第三题:计算5个整数的平均值

问题描述:
编写一个C语言程序,该程序要求用户输入5个整数,并将这些整数存储在一个数组中。程序需要计算并输出这5个整数的平均值。

要求:

  1. 定义一个长度为5的整数数组用于存储用户输入的整数。
  2. 使用循环结构(如while循环)从用户处获取5个整数,并将它们存储在数组中。
  3. 计算数组中所有数字的总和。
  4. 计算平均值,并将结果存储在变量中。
  5. 使用printf函数输出平均值。

注意:

  • 平均值应使用整数除法进行计算,这意味着结果将是一个整数。如果需要更精确的结果,可以考虑使用浮点数除法。
  • 在输入每个数字时,应提示用户输入相应的数字(例如,“请输入第1个数字:”,“请输入第2个数字:”,依此类推)。

输出:

请输入第1个数字: 5

请输入第2个数字: 10

请输入第3个数字: 15

请输入第4个数字: 20

请输入第5个数字: 25

平均值 = 15

示例代码:

#include <stdio.h>int main()
{// 编写一个程序,要求用户输入5个整数,将它们存储在一个数组中,然后计算并输出这5个整数的平均值。// 1. 定义变量保存用户输入的整数int num[5];// 2. 初始化 用于while循环次数和数组赋值下标int i = 0;// 3. 用于存储所有数字累加的和int sum = 0;// 4. 定义变量保存计算结果int resule = 0;// 5. 开始输入 到第5个数字结束while (i < 5){printf("请输入%d个数字:\n", i + 1);scanf("%d", &num[i]);i++;}// 6. 数组长度int len = sizeof(num) / sizeof(num[0]);// 7. 循环数组for (int i = 0; i < len; i++){// 7.1 所有数字相加的和sum += num[i];}// 8 计算平均值resule = (sum / len);printf("平均值 = %d\n", resule);return 0;
}

 运行结果:

第四题:查找整数在数组中的索引位置

问题描述:
编写一个C语言程序,该程序包含一个名为find_index的函数,该函数接受一个整数数组、数组的长度和一个待查找的整数作为参数。函数的任务是查找该整数在数组中的索引位置,并返回该索引。如果整数在数组中不存在,则函数应返回-1。

main函数中,应定义一个包含10个元素的整数数组,并调用find_index函数来查找一个特定的整数在数组中的索引位置。最后,程序应输出找到的索引或-1(如果整数不存在于数组中)。

要求:

  1. find_index函数应使用循环遍历数组,直到找到目标整数或遍历完整个数组。
  2. 如果找到目标整数,函数应立即返回其索引位置。
  3. 如果遍历完整个数组仍未找到目标整数,函数应返回-1。
  4. main函数中应初始化一个包含10个元素的数组,并调用find_index函数来查找一个特定的整数。
  5. 使用printf函数输出找到的索引或-1。

输出:

下标 = 6

示例代码:

#include <stdio.h>
// 编写一个函数find_index,接受一个整型数组、数组的长度和一个整数作为参数,查找并返回该整数在数组中的索引位置。
// 如果该整数不存在于数组中,则返回-1。在主函数中定义一个包含10个元素的数组,并调用find_index函数查找某个整数的索引位置并输出。int find_index(int *arr, int len, int num)
{for (int i = 0; i < len; i++){if (arr[i] == num){return i;}}return -1;
}int main()
{// 1. 定义数组int arr[10] = {1, 2, 3, 55, 34, 12, 98, 5, 7, 8};// 2. 长度int len = sizeof(arr) / sizeof(arr[0]);// 3. 调用方法 传递参数int res = find_index(&arr, len, 98);printf("下标 = %d\n", res);return 0;
}

 运行结果:

第五题:统计字符串中数字字符的个数

问题描述:
编写一个C语言程序,该程序接受用户输入的一个字符串,并统计该字符串中数字字符(0-9)的个数。程序应定义一个函数来计算并返回数字字符的数量,然后在主函数中调用该函数并输出结果。

要求:

  1. 定义一个函数getlen,该函数接受一个字符串(使用字符指针表示)作为参数,并返回该字符串中数字字符的数量。
  2. getlen函数中,使用一个循环来遍历字符串的每个字符,并检查它是否是数字字符(即字符的ASCII值是否在'0'到'9'之间)。
  3. 如果字符是数字字符,则递增一个计数器。
  4. 当字符串的末尾字符('\0')被遇到时,停止循环,并返回计数器的值。
  5. main函数中,定义一个字符数组(或字符指针数组)来存储用户输入的字符串。
  6. 使用gets函数从用户处获取字符串输入,并存储在定义的字符数组中。
  7. 调用getlen函数,并将字符数组的地址作为参数传递。
  8. 使用printf函数输出字符串中数字字符的数量。

注意:

  • gets函数在某些编译器或环境下可能被视为不安全,因为它不检查目标数组的大小,可能会导致缓冲区溢出。在实际应用中,建议使用更安全的字符串输入函数,如fgets
  • 由于str是一个字符指针数组,而gets函数期望一个字符数组(即char数组)作为参数,因此str的定义应改为char str[50];而不是char *str[50];

输出:

请输入一个字符串: Hello123World456

字符串数字个数 = 6

运行结果:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/821079.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

由于找不到krpt.dll,无法继续执行代码的5种解决方法

在正常使用电脑的过程中&#xff0c;当尝试启动某个应用程序或者执行特定功能时&#xff0c;系统突然弹出一个错误提示窗口&#xff0c;明确指出由于缺失关键性文件——krpt.dll&#xff0c;导致当前运行的软件无法正常读取并执行相应的程序代码&#xff0c;进而无法顺利完成预…

【JavaSE】你真的了解内部类吗?

前言 本篇会详细讲解内部类的四种形式&#xff0c;让你掌握内部类~ 欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 目录 前言 内部类介绍 实例内部类 定义 调用 静态内部类 定义 调用 匿名内部类 定义和调用1 调用方法2 …

【数据结构与算法】之双向链表及其实现!

​ 个人主页&#xff1a;秋风起&#xff0c;再归来~ 数据结构与算法 个人格言&#xff1a;悟已往之不谏&#xff0c;知来者犹可追 克心守己&#xff0c;律己则安&#xff01; 目录 1、双向链表的结构及概念 2、双向链表的实现 2.1 要实现的接口…

深度学习 Lecture 8 决策树

一、决策树模型&#xff08;Decision Tree Model) 椭圆形代表决策节点&#xff08;decison nodes)&#xff0c;矩形节点代表叶节点&#xff08;leaf nodes)&#xff0c;方向上的值代表属性的值&#xff0c; 构建决策树的学习过程&#xff1a; 第一步&#xff1a;决定在根节点…

Towards Street-Level Client-Independent IP Geolocation(2011年)(第一部分)

被引次数:306 Wang Y, Burgener D, Flores M, et al. Towards {Street-Level}{Client-Independent}{IP} Geolocation[C]//8th USENIX Symposium on Networked Systems Design and Implementation (NSDI 11). 2011. Abstract 一个高度精确的客户端独立的地理定位服务将是互联…

箭头函数有哪些不适用场景

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

元类的执行

class MetaB(type):def __new__(cls, name, bases, attrs):print(f"使用元类 {cls.__name__} 创建{name}类 ")return super().__new__(cls, name, bases, attrs)class A(metaclassMetaB):passclass C(A):pass元类MetaB的__new__方法应该只会在创建类A时被调用一次, 因…

单例模式五种写法

单例模式五种写法 单例模式有五种写法&#xff1a;饿汉、懒汉、双重检验锁、静态内部类、枚举. 单例模式属于设计模式中的创建型模式 一、单例模式应用场景 windows的task manager(任务管理器)就是很典型的单例模式; windows的recycle bin(回收站)也是典型的单例应用&#…

Composer是什么?

Composer是PHP的一个依赖管理工具&#xff0c;它允许开发者声明项目所依赖的代码库&#xff0c;并在项目中自动安装这些依赖。它使用composer.json文件来定义项目的依赖关系&#xff0c;并使用composer.lock文件来锁定依赖的版本&#xff0c;以确保项目的稳定性和可重复性。 Co…

物联网的核心价值是什么?——青创智通

工业物联网解决方案-工业IOT-青创智通 物联网&#xff0c;这个词汇在当今的科技领域已经变得耳熟能详。但当我们深入探索物联网的核心价值时&#xff0c;我们会发现它远不止是一个简单的技术概念&#xff0c;而是一种能够彻底改变我们生活方式和工作方式的革命性力量。 物联网…

力扣周赛392复盘

3105. 最长的严格递增或递减子数组 题目 给你一个整数数组 nums 。 返回数组 nums 中 严格递增 或 严格递减 的最长非空子数组的长度。 思考&#xff1a; 返回什么&#xff1a;返回最长非空子数组的长度。return max(decs_len,incs_len); 但实际上我们只需要用一个变量ans就…

[leetcode] max-area-of-island

. - 力扣&#xff08;LeetCode&#xff09; 给你一个大小为 m x n 的二进制矩阵 grid 。 岛屿 是由一些相邻的 1 (代表土地) 构成的组合&#xff0c;这里的「相邻」要求两个 1 必须在 水平或者竖直的四个方向上 相邻。你可以假设 grid 的四个边缘都被 0&#xff08;代表水&…

Java | Leetcode Java题解之第22题括号生成

题目&#xff1a; 题解&#xff1a; class Solution {static List<String> res new ArrayList<String>(); //记录答案 public List<String> generateParenthesis(int n) {res.clear();dfs(n, 0, 0, "");return res;}public void dfs(int n ,int…

牛客网刷题 | BC51 及格分数

描述 KiKi想知道他的考试分数是否通过&#xff0c;请帮他判断。从键盘任意输入一个整数表示的分数&#xff0c;编程判断该分数是否在及格范围内&#xff0c;如果及格&#xff0c;即&#xff1a;分数大于等于60分&#xff0c;是输出“Pass”&#xff0c;否则&#xff0c;输出“…

利用vite创建vue项目

创建vue项目步骤 打开HBuilder X工具&#xff0c;创建空白项目 进入终端(鼠标点击文件进行选择&#xff0c;然后终端) 利用vite脚手架创建项目 &#xff08;前提要将HBuilder X工具属性设为管理员运行状态&#xff08;属性》兼容》管理员身份运行此程序&#xff09; npm …

Ubuntu22.04配置ROS2+PX4仿真环境

Ubuntu22.04配置ROS2PX4仿真环境 主要参考源&#xff1a; https://blog.csdn.net/weixin_44174421/article/details/135827130 https://blog.csdn.net/Zecet/article/details/130474620 一、准备工作 确保网络能够连接到github&#xff0c;出错主要源自于此&#xff1b;确保…

【Qt 学习笔记】Qt常用控件 | 按钮类控件Check Box的使用及说明

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt常用控件 | 按钮类控件Check Box的使用及说明 文章编号&#xff1a;…

C# 两种方法截取活动窗口屏幕,实现窗体截图

方法1&#xff0c;截屏内容仅包括活动窗口界面&#xff0c;而方法2是从屏幕范围取图&#xff0c;截屏内容会包括屏幕上所有内容。例如有一些程序在桌面顶层显示半透明的悬浮窗&#xff0c;用方法2截屏就会包括这些内容&#xff0c;并不是单纯的活动窗口内容。 方法1&#xff0c…

解决 MSYS2 Qt 6.7 默认 stylesheet 在 windows 11 下的显示故障

项目场景&#xff1a; MSYS2 升级到 Qt6.7.0&#xff0c;发现显示故障&#xff0c;所有Qt6程序以及 QtCreator的SpinBox都显示不全&#xff0c;Combox的底色不对。 问题描述 2024年4月1日&#xff0c;pacman升级MSYS2后&#xff0c;Qt6遇到风格错误。如果使用官方的 Qt onlin…

【PostgreSQL里insert on conflict do操作时的冲突报错分析】

最近在巡检PostgreSQL的数据库的时候&#xff0c;发现部分数据库里存在大量的如下报错 ERROR: ON CONFLICT DO UPDATE command cannot affect row a second time HINT: Ensure that no rows proposed for insertion within the same command have duplicate constrained val…