嵌入式学习——C语言基础——day6

1. 一维数组的定义

        相同类型有限数据的一个集合

        数据类型 数组名[元素个数];

        注意:

        1. 数组中的元素必须为同一类型

        2. 元素个数有限个

        3. 数组定义时,元素个数必须为常量或者常量表达式,不能为变量

2. 数组元素的访问

        数组名[元素下标]

        元素下标可以为常量、变量、或常量变量表达式

3. 数组元素的初始化

3.1 全部初始化

        int a[5] = {1, 2, 3, 4, 5};

3.2 局部初始化

        int a[5] = {1, 2, 3};

        没有给定初值的元素统一给0值

3.3 默认初始化

        int a[] = {1, 2, 3, 4, 5};

        注意:初始化 不等同于 赋值

4. 数组的储存

4.1 连续性

        数组存储空间连续

4.2 有序性

        数组存放顺序有序

        注意:计算元素个数方法   sizeof(a) / sizeof(a[0]);

5. 数组的常见操作

5.1 获得最大值

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int min = 0;int len = sizeof(a) / sizeof(a[0]);for (i = 0; i < len; i++){scanf("%d", &a[i]);}max = a[0];for (i = 1; i < len; i++){if (a[i] > max){min = a[i];}}printf("max = %d\n", max);return 0;
}

5.2 获得最小值

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int min = 0;int len = sizeof(a) / sizeof(a[0]);for (i = 0; i < len; i++){scanf("%d", &a[i]);}min = a[0];for (i = 1; i < len; i++){if (a[i] < min){min = a[i];}}printf("min = %d\n", min);return 0;
}

5.3 获得最大值下标

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int max = 0;int len = sizeof(a) / sizeof(a[0]);for (i = 0; i < len; i++){scanf("%d", &a[i]);}max = a[0];for (i = 1; i < len; i++){if (a[i] > max){max = i;}}printf("max = %d\n", max);return 0;
}

5.4 获得最小值下标

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int min = 0;int len = sizeof(a) / sizeof(a[0]);for (i = 0; i < len; i++){scanf("%d", &a[i]);}min = a[0];for (i = 1; i < len; i++){if (a[i] < min){min = i;}}printf("min = %d\n", min);return 0;
}

5.5 数组元素倒置

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int tmp = 0;int len = sizeof(a) / sizeof(a[0]);for (i = 0; i < len; i++){scanf("%d", &a[i]);}for (i = 0; i < len/2; i++){tmp = a[i];a[i] = a[len-1-i];a[len-1-i] = tmp;}for (i = 0; i < len; i++){printf("%d ", a[i]);}putchar('\n');return 0;
}

5.6 冒泡排序法

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int j = 0;int len = sizeof(a) / sizeof(a[0]);int tmp = 0;for (i = 0; i < len; i++){scanf("%d", &a[i]);}for (i = 0; i < len-1; i++)              //min -> max{for (j = 0; j < len-1-i; j++)     {if (a[j] > a[j+1]){tmp = a[j];a[j] = a[j+1];a[j+1] = tmp;}}}for (i = 0; i < len; i++){printf("%d ", a[i]);}putchar('\n');return 0;
}

5.7 选择排序法

#include <stdio.h>int main(void)
{int a[5] = {0};int i = 0;int j = 0;int len = sizeof(a) / sizeof(a[0]);int tmp = 0;int min = 0;for (i = 0; i < len; i++){scanf("%d", &a[i]);}for (i = 0; i < len-1; i++)              //min -> max{min = i;for (j = i+1; j < len; j++)     {if (a[j] < a[min]){min = j;}}if (min != i){tmp = a[min];a[min] = a[i];a[i] = tmp;}}for (i = 0; i < len; i++){printf("%d ", a[i]);}putchar('\n');return 0;
}

        

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

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

相关文章

深度剖析图像处理—边缘检测

什么是边缘检测 边缘检测(Edge Detection)就是提取图像中的边缘点(Edge Point)。边缘点是与周围像素相比灰度值有阶跃变化或屋顶状变化的像素。边缘常存在于目标与背景之间、目标与目标之间、目标与其影子之间。 ​ 在图像处理和图像分析中&#xff0c;经常要用到边缘(Edge)、边…

【Git】生成patch和应用patch

生成patch 将本地所有修改打成补丁 git diff > /tmp/xxx.patch将本地对某个文件的修改打成补丁 git diff test/1.txt > /tmp/1.patch将某一次提交的修改内容打成补丁 -1表示只为单个提交创建patch&#xff0c;-o表示输出patch的文件夹路径&#xff0c;默认是用提交的…

D咖饮品机器人惊艳亮相:智能硬件改变生活习惯

在当今快节奏的生活中&#xff0c;人们对于便捷、高效的需求日益增长&#xff0c;智能硬件应运而生&#xff0c;其中饮品机器人作为一种新型的智能设备&#xff0c;正在以惊艳的姿态亮相于人们的生活中&#xff0c;为人们带来了全新的消费体验&#xff0c;改变着大众的生活习惯…

node-sass安装失败解决

老项目安装node-sass4.14.1一直失败 "node-sass": "^4.14.1",报错环境变量Path 中没有 python2.7 gyp verb check python checking for Python executable "python2.7" in the PATH安装python2.7,然后设置npm config set python C:\Python27 …

vulfocus的使用

vulfocus的使用 1.拉取镜像 docker pull vulfocus/vulfocus:latest 2.运行 docker run -d -p 80:80 -v /var/run/docker.sock:/var/run/docker.sock -e VUL_IP192.168.0.105 vulfocus/vulfocus 3.访问 用户名&#xff1a;admin 密码&#xff1a;admin

【机器学习】特征筛选实例与代码详解

机器学习中的特征筛选 一、特征筛选的重要性与基本概念二、特征筛选的方法与实践1. 基于统计的特征筛选2. 基于模型的特征筛选3. 嵌入式特征筛选 三、总结与展望 在机器学习领域&#xff0c;特征筛选作为预处理步骤&#xff0c;对于提高模型性能、简化模型结构以及增强模型解释…

街道社区信息宣传工作做的好这个投稿方法不能少

作为一名刚刚接手街道社区信息宣传工作的新人,伊始对于如何有效地向各大媒体平台投稿我可谓是一头雾水。那时的日子充满了曲折与挑战,每一步都似乎布满了荆棘。为了让更多居民了解社区的工作动态和服务亮点,我怀揣着满腔热情,着手撰写一篇篇生动详实的新闻稿件。然而,投稿的过程…

SpringAOP从入门到源码分析大全(三)ProxyFactory源码分析

文章目录 系列文档索引五、ProxyFactory源码分析1、案例2、认识TargetSource&#xff08;1&#xff09;何时用到TargetSource&#xff08;2&#xff09;Lazy的原理&#xff08;3&#xff09;应用TargetSource 3、ProxyFactory选择cglib或jdk动态代理原理4、jdk代理获取代理方法…

算法导论 总结索引 | 第三部分 第十一章:散列表

1、动态集合结构&#xff0c;它至少要支持 INSERT、SEARCH 和 DELETE字典操作 散列表 是实现字典操作的 一种有效的数据结构。尽管 最坏情况下&#xff0c;散列表中 查找一个元素的时间 与链表中 查找的时间相同&#xff0c;达到了 Θ(n)。在实际应用中&#xff0c;散列表的性…

CB2-2CARD之Debian(Bookworm)安装Gnome看CCTV

CB2-2CARD之Debian&#xff08;Bookworm&#xff09;安装Gnome看CCTV 1. 源由2. 需求3. Debian系统桌面3.1 系统安装3.2 磁盘扩容3.3 系统更新3.4 Gnome安装 4. 测试4.1 CCTV网页测试4.2 系统空闲测试4.3 Firefox CPU占用率测试 5. 总结 1. 源由 近些年来&#xff0c;随着国内…

【学习笔记】Vue3源码解析:第五部分 - 实现渲染(3)

课程地址&#xff1a;【已完结】全网最详细Vue3源码解析&#xff01;&#xff08;一行行带你手写Vue3源码&#xff09; 第五部分-&#xff1a;&#xff08;对应课程的第36 - 37节&#xff09; 第36节&#xff1a;《处理proxy&#xff0c;方便取值》 1、执行组件中的 render 方…

Golang 开发实战day11 - Pass By Value

&#x1f3c6;个人专栏 &#x1f93a; leetcode &#x1f9d7; Leetcode Prime &#x1f3c7; Golang20天教程 &#x1f6b4;‍♂️ Java问题收集园地 &#x1f334; 成长感悟 欢迎大家观看&#xff0c;不执着于追求顶峰&#xff0c;只享受探索过程 Golang 开发实战day11 - 按值…

vector的底层与使用

前言&#xff1a;vector是顺序表&#xff08;本质也是数组&#xff09; 文档参考网站&#xff1a;https://legacy.cplusplus.com/reference/vector/vector/vector/ //底层代码 #include<assert.h> #include<iostream> #include<vector> #include<string&g…

第二部分-Foundation基础-学习导航

专题地址&#xff1a;MacOS一站式程序开发系列专题 第一部分&#xff1a;基础入门-学习导航 ObjectiveC-第一部分-基础入门-学习导航 第二部分&#xff1a;Foundation基础学习导航 Foundation框架-13-数据对象&#xff1a;主要讲述NSRange, NSString, NSValue, NSNull, NSD…

CFCASSL证书的网络安全解决方案

在数字化时代&#xff0c;网络信息安全的重要性不言而喻。随着电子商务、在线交易、远程办公等互联网活动的日益普及&#xff0c;确保数据传输的安全性与隐私保护成为企业和用户共同关注的焦点。在此背景下&#xff0c;CFCA SSL证书作为一种权威、高效的网络安全解决方案&#…

[LitCTF 2023]PHP是世界上最好的语言!!、 [LitCTF 2023]Vim yyds、 [羊城杯 2020]easycon

目录 [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; [LitCTF 2023]Vim yyds [羊城杯 2020]easycon [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; 无参&#xff0c;根据题目提示看看php能否执行——返回1执行成功 用system()函数调用、执行ls …

C++教你如何模拟实现string,如何实现string写时拷贝

文章目录 前言成员变量默认成员函数默认构造函数拷贝构造函数析构函数赋值运算符重载 容量相关函数&#xff08;Capacity&#xff09;reserve函数resize函数size函数capacity 函数clear函数 修改函数&#xff08;Modifiers&#xff09;swap函数insert函数字符插入字符串插入 ap…

基于docker搭建瀚高数据库HighGo6.0.1【图文】

基于docker搭建瀚高数据库HighGo6.0.1 拉取镜像启动验证进入容器 登录数据库查看数据库加密方式修改加密方式为sm3进入数据库修改密码重启容器 数据库验证数据库密码到期参考 docker部署 https://blog.csdn.net/weixin_44385419/article/details/127738868 拉取镜像 docker p…

【Java】变量零基础教程

目录 一、引言 二、基本组成单位 三、变量的基本原理 四、变量的基本使用步骤 五、变量快速入门 六、变量使用的注意事项 一、引言 为什么需要变量&#xff1f; ​​​​​​一个程序就是一个世界。 大家看下图&#xff0c;是我们现实中的一张生活照&#xff0c;图里有树…

spring aop介绍

Spring AOP&#xff08;面向切面编程&#xff09;是一种编程范式&#xff0c;它允许开发者将横切关注点&#xff08;cross-cutting concerns&#xff09;从业务逻辑中分离出来&#xff0c;从而提高代码的模块化。在传统的对象导向编程中&#xff0c;这些横切关注点&#xff0c;…