iOS笔记:第七篇 C语言 数组

2024-09-02 12:08

本文主要是介绍iOS笔记:第七篇 C语言 数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


第一节            数   组

1. 数组

 作用:用来存储多个数据.

 数组与普通变量的区别:

     1数组可以存储多个数据,普通变量只能存储一个数据

     2数组中的多个数据共存,普通变量只能有一个.

 数组的特点:

     1)存储多个数据

     2存储的多个数据的类型必须要相同.这个类型在创建数组的时候指定.

     3数组的长度固定.数组可以存储的数据的个数是固定的.

           在创建数组的时候就要指定这个数组到底能存储多少个数据.

            一旦指定,无法更改.

     4存储在数组中的数据非常方便管理.

  数组其实就是用来存储一组数据.

2. 如何去创建1个用于存储多个数据的数组.

1).在创建数组之前要确定的事情

    -> 数组之中能够存储那些类型的数据.

    -> 数组之中要存储多少个数据.

2).语法:

      数组之中存储的数据的类型数组名称[数组之中能够存储的数据的个数];

      array: 数组.

      int arr[3];

       表示.创建了1个数组.数组的名字叫做arr.这个数组可以存储3个数据,1个数据的类型要求都是int类型的.

3).数组是用来存储多个数据.既然是来存储数据的那么就必须要在内存中开辟空间.

    划分为多少个小空间是根据声明数组的时候,中括弧中的数字来决定的.每一个小空间的类型是根据声明数组的时候,指定的每一个数据的类型来决定的.这些小空间就是用来存储数据的.

    4).专业的术语

   元素:数组之中用来存储数据的每一个小空间就叫做数组的元素.

    下标/索引:为了区分数组中的每一个元素.C就为每一个元素编了一个号码这个号码从0开始依次的递增.这个号码就叫做元素的下标.

    数组的长度:数组之中能存储多少个数据.

3. 如何往数组之中存储数据.

1). 数组之中存储数据的是数组的元素.我们应该将数据赋值给数组的元素而不数组.

       int arr[3];

       arr = 10; 这么写是错误的.因为真正存储数据的是数组之中的元素.

2). 我们往数组之中存储数据,实际上应该将数据赋值给数组之中的元素.

       数组之中有很多个元素,通过数组的下标来确定.

        语法:数组名[下标] = 数据;

       arr[0] = 10;  10这个数据赋值给arr数组之中的下标为0的元素.

        注意: arr[0]指的是 arr数组中下标为0的元素.

3). 注意:

      1)如果为元素赋的值的类型和元素的类型不一致,这个时候就会做类型转换.

      2)下标越界的问题.就是访问数组的元素的时候注意下标不要超过范围.

           数组的下标的范围: 0 ->长度-1

4. 如何将数组中的数据取出来.

1). 数组中有很多个元素,通过下标来确定.

      数组名[元素的下标];

2). 取值的时候也要注意下标越界问题,如果下标越界了,取出来的值就是一个垃圾值.

5.数组的遍历

  遍历的原理:将数组的元素的每1个下标遍历出来.

              0 --> 长度-1将这个范围中的每1个整数遍历出来

              当做数组的下标取出.

    for(int i = 0; i < 数组的长度; i++)

   {

        arr[i] 就可以拿到每1个元素的值;

   }

6. 数组要注意的细节问题

1.数组的声明.

      元素的类型数组名[数组的长度];

      指定长度的时候不能是负数但是可以是0但是没有意义.

       数组的长度可以用变量

      数组的长度也可以用1个表达式.

2.数组的初始化

  ->. 如果我们声明一个数组,没有为数组的元素赋值,那么数组的元素的值一个垃圾值.

   -> 声明数组的元素的同时就为数组的元素赋值.

           int arr[5] = {10,20,30,40,50};

           在大括弧中的数据会依次的赋值给每一个元素.

           但是在给值的时候,数据的个数不要超过元素的个数.

           int arr[] = {10,20,30,40,60,70}

           数组的个数根据后面给的数据的个数来定

           算数组的长度:数组占用的字节数 / 1个元素占用的字节数.

           int arr[5] = {1,2};

           后面值给1个数据.按照顺序赋值给每1个元素.如果没有初始化的元素就自动的初始化为0.

           只要有1个元素被初始化了那么其他的元素就被自动初始化为0.

   也可以指定初始化数据为那个元素.没有指定初始化的元素自动初始化为0.

 

第二节 数组的存储

1. 变量在内存中如何存储的.

1). 内存中存储数据的最小基本单位是字节.1个字节由8个二进制位组成.

  并且每1个字节在内存之中都有1个独一无二的地址.

 2).声明1个变量实际上就是在内存中申请指定个数字节的空间用来存储数据.

 int num; 4         float     4

 double   8        char      1

 3). 为变量申请字节空间的时候,是由高地址向低地址申请的.

 先声明的变量在高地址.后声明的变量在低地址.

4). 变量中的数据都是数据的补码二进制形式存储的.

 低位存储在低字节.高位存储在高字节.

5). 变量的地址

 是变量中首字节的地址.

6). 如何取出变量的地址.

  &取地址符.  %p

2. 数组在内存中是如何存储的.

a. 数组其实就是在内存中申请连续的空间用来存储数据.

   int arr[3]; 在内存之中申请3个连续的int类型的空间.

 

 b.数组的第0个元素低字节的那个变量.

 c.为每1个元素赋值的时候.是将数据的补码存储在对应的字节之中.

3. 数组的长度的计算方法.

数组占用的字节数: 数组中所有的元素占用的字节数.

元素占用的字节数: 1个元素占用的字节数.

如何计算数组中元素的个数 数组占用的字节数 1个元素占用的字节数.

sizeof(数组) /  sizeof(元素类型);

4. 数组的地址问题.

数组的地址是下标为0的元素的地址.

     而数组的第0个元素的地址0个元素的低字节的地址.

 数组名中存储的是数组的地址.

5. 元素的地址

 拿到数组的元素的地址.

数组的元素的本质是变量.

通过取地址符来拿到.

 &arr[0];

如果要通过scanf为数组的元素赋值.要取到元素的地址传入

    int arr[3] = {10,20,30};

    arr 数组名种存储的是数组的地址.

    数组的地址是:0个元素的地址也就是第0个元素的低字节的地址.

     arr[0]; 这个是拿到下标为0的元素的值.

    &arr[0]; 这个是拿到下标为0的元素的地址,也就是数组的地址.

数组名 ==  数组的地址 == 下标为0的元素的地址 ==下标为0的元素的低字节的地址

4. 数组越界

    a. 当访问数组中不存在的元素的时候,运行会报错.

    b. 取值的时候,下标如果越界了,那么取到的值是一个垃圾值.

    c. 越界访问的时候编译器是允许的.但是不要这么做.

        因为当越界访问的时候,访问到的不是数组的元素了,极度有可能你访问到的空间是被系统占用的,也有可能是别的程序占用的.越界访问很危险

 

第三节

1、  选择排序




2.冒泡排序:







这篇关于iOS笔记:第七篇 C语言 数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129914

相关文章

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

基于Python实现多语言朗读与单词选择测验

《基于Python实现多语言朗读与单词选择测验》在数字化教育日益普及的今天,开发一款能够支持多语言朗读和单词选择测验的程序,对于语言学习者来说无疑是一个巨大的福音,下面我们就来用Python实现一个这... 目录一、项目概述二、环境准备三、实现朗读功能四、实现单词选择测验五、创建图形用户界面六、运行程序七、