精华内容
下载资源
问答
  • C语言总结第七章、数组一维数组一维数组的定义一维数组的引用一维数组的初始化程序举例二维数组及多维数组二维数组的定义二维数组元素的引用二维数组元素的初始化程序举例字符数组和字符串字符数组 第七章、数组 ...

    第七章、数组

    数组是构造数据类型之一

    • 数组: 有序数据的集合,用数组名标识
    • 元素: 属同一数据类型,用数组名和下标确定

    一维数组

    一维数组的定义

    定义方式:
    在这里插入图片描述
    例: int a[6]
    在这里插入图片描述

    一维数组的引用

    1、数组必须先定义,后使用。
    2、只能逐个引用数组元素,不能一次引用整个数组。
    3、数组元素表示形式: 数组名[下标] ,下标可以是常量或整型表达式

    一维数组的初始化

    初始化方式:
    在这里插入图片描述

    说明:
    1、数组不初始化,其元素值为随机数。
    2、对static数组元素不赋初值,系统会自动赋以0值。
    在这里插入图片描述
    3、只给部分数组元素赋初值。
    在这里插入图片描述
    4、当全部数组元素赋初值时,可不指定数组长度。
    在这里插入图片描述

    程序举例

    例1: 读10个整数存入数组,找出其中最大值和最小值
    在这里插入图片描述

    /*示例1*/
    #include <stdio.h>
    #define SIZE 10
    main()
    {   int x[SIZE],i,max,min;
        printf("Enter 10 integers:\n");
        for(i=0;i<SIZE;i++)
        {   printf("%d:",i+1);
    	scanf("%d",&x[i]);
        }
        max=min=x[0];
        for(i=1;i<SIZE;i++)
        {  if(max<x[i])  max=x[i];
           if(min>x[i])  min=x[i];
        }
        printf("Maximum value is %d\n",max);
        printf("Minimum value is %d\n",min);
    }
    

    例2: 用数组求Fibonacci数列前20个数
    在这里插入图片描述

    /*示例2*/
    #include <stdio.h>
    main()
    {   int i;
         int f[20]={1,1};
        for(i=2;i<20;i++)
           f[i]=f[i-2]+f[i-1];
        for(i=0;i<20;i++)
        {   if(i%5==0)  printf("\n");
             printf("%12d",f[i]);
        }
    }
    

    例3: 用冒泡法对10个数排序
    在这里插入图片描述
    在这里插入图片描述

    /*示例3*/
    #include <stdio.h>
    main()
    {   int a[11],i,j,t;
        printf("Input 10 numbers:\n");
        for(i=1;i<11;i++)
           scanf("%d",&a[i]);
        printf("\n");
        for(j=1;j<=9;j++)
           for(i=1;i<=10-j;i++)
              if(a[i]>a[i+1])
             {t=a[i]; a[i]=a[i+1]; a[i+1]=t;}
        printf("The sorted numbers:\n");
        for(i=1;i<11;i++)
    	printf("%d ",a[i]);
    }
    

    例4: 用简单选择法对10个数排序

    在这里插入图片描述

    在这里插入图片描述

     /*示例4*/
    #include <stdio.h>  
    main()
    {   int a[11],i,j,k,x;
        printf("Input 10 numbers:\n");
        for(i=1;i<11;i++)
           scanf("%d",&a[i]);
        printf("\n");
       for(i=1;i<10;i++)
       {  k=i;
          for(j=i+1;j<=10;j++)
                if(a[j]<a[k])  k=j;
          if(i!=k)
          {  x=a[i]; a[i]=a[k]; a[k]=x;}
       }
        printf("The sorted numbers:\n");
        for(i=1;i<11;i++)
    	printf("%d ",a[i]);
    }
    

    二维数组及多维数组

    二维数组的定义

    定义方式: 
    在这里插入图片描述
    在这里插入图片描述
    数组元素的存放顺序
    1、原因: 内存是一维的
    2、二维数组: 按行序优先
    3、多维数组: 最右下标变化最快

    在这里插入图片描述
    数组a[m][n],m行n列,共m*n个元素
    在这里插入图片描述

    这些元素占用m*n个单元,每个单元的大小取决于
    元素的类型。

    任意元素a[i][j]在数组中的位置计算公式为:

    i×n+j (从0开始)

    a——数组的起始地址;a[0]——0行0列元素的地址。

    二维数组元素的引用

    形式: 数组名[下标][下标]

    二维数组元素的初始化

    1、分行初始化
    2、按元素排列顺序初始化

    程序举例

    例1:将二维数组行列元素互换,存到另一个数组中
    在这里插入图片描述

    /*示例1*/
    #include <stdio.h>
    main()
    {   int a[2][3]={{1,2,3},{4,5,6}};
         int b[3][2],i,j;
        printf("array a:\n");
        for(i=0;i<=1;i++)
        {   for(j=0;j<=2;j++)
    	{   printf("%5d",a[i][j]);
    	    b[j][i]=a[i][j];
    	}
    	printf("\n");
        }    
        printf("array b:\n");
        for(i=0;i<=2;i++)
        {   for(j=0;j<=1;j++)
    	   printf("%5d",b[i][j]);
             printf("\n");
        }
    }
    

    例2:求二维数组中最大元素值及其行列号
    在这里插入图片描述

    /*示例2*/
    #include <stdio.h>
    main()
    {  int a[3][4]={{1,2,3,4},
                            {9,8,7,6},
                            {-10,10,-5,2}};
        int i,j,row=0,colum=0,max;
        max=a[0][0];
        for(i=0;i<=2;i++)
           for(j=0;j<=3;j++)
               if(a[i][j]>max)
    	  {  max=a[i][j];
    	     row=i;
    	     colum=j;
    	  }
        printf("max=%d,row=%d,\colum=%d\n",max,row,colum);
    }
    

    例3:分别求n阶方阵两条对角线上的元素之和

    /*示例3*/
    #define N 3
    main()
    {   int i,j,a[N][N];
    int sum1=0,sum2=0;
    for(i=0;i<N;i++)
      for(j=0;j<N;j++)
        scanf(%d”,&a[i][j]);
    for(i=0;i<N;i++)
      for(j=0;j<N;j++)
        if(i==j) sum1+=a[i][j];
    for(i=0;i<N;i++)
      for(j=N-1;j>=0;j--)
        if((i+j)==N-1) sum2+=a[i][j];
    printf(“sum1=%d,sum2=%d\n”,sum1,sum2);
    }
    

    字符数组和字符串

    字符数组

    定义 : 每个元素存一个字符,主要用来对字符串操作。
    字符数组的初始化:

    1、逐个字符赋值
    2、用字符串常量

    字符数组的引用:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述

    字符串

    字符串及其结束标志

    (1)、无字符串变量,用字符数组处理字符串。
    (2)、字符串结束标志:‘\0’。

    在这里插入图片描述
    字符串的输入输出
    输入:

    • 用scanf函数
      (1).输入单个字符:%c 需用循环语句
      (2).输入字符串:%s scanf(“%s”,str);
    • 用gets函数:gets(str);

    输出:

    • 用printf函数
      (1).输出单个字符:%c 需用循环语句
      (2).输出字符串:%s printf(“%s”,str);
    • 用puts函数:puts(str);

    在这里插入图片描述

    常用的字符串处理函数: 加粗样式包含在头文件 string.h

    字符串输出函数puts

    格式: puts(字符数组)
    功能: 向显示器输出字符串(输出完,换行)
    说明: 字符数组必须以‘\0’结束

    字符串输入函数gets

    格式: gets(字符数组)
    功能: 从键盘输入一以回车结束的字符串放入字符数组中,并自动加‘\0’
    说明: 输入串长度应小于字符数组维数

    字符串连接函数strcat

    格式: strcat(字符数组1,字符数组2)
    功能: 把字符数组2连到字符数组1后面
    返值: 返回字符数组1的首地址
    说明:
    1、字符数组1必须足够大
    2、连接前,两串均以‘\0’结束;连接后,串1的‘\0’取消, 新串最后加‘\0’

    字符串拷贝函数strcpy

    格式: strcpy(字符数组1,字符串2)
    功能: 将字符串2,拷贝到字符数组1中去
    返值: 返回字符数组1的首地址
    说明:
    1、字符数组1必须足够大
    2、拷贝时‘\0’一同拷贝
    3、不能使用赋值语句为一个字符数组赋值
    在这里插入图片描述

    字符串比较函数strcmp

    格式: strcmp(字符串1,字符串2)
    功能: 比较两个字符串
    比较规则: 对两串从左向右逐个字符比较(ASCII码),直到遇到不同字符或‘\0’为止
    返值: 返回int型整数,
    a. 若字符串1< 字符串2, 返回负整数
    b. 若字符串1> 字符串2, 返回正整数
    c. 若字符串1== 字符串2, 返回零
    说明: 字符串比较不能用“==”,必须用strcmp

    字符串比较函数strcmp

    字符串长度函数strlen
    格式:strlen(字符数组)
    功能:计算字符串长度
    返值:返回字符串实际长度,不包括‘\0’在内
    在这里插入图片描述

    展开全文
  • 用C++语音实现一维数组二维数组写入txt,从txt中读取数据存到一维数组、二维数组,数组用指针表示
  • 一维数组与二维数组区别

    万次阅读 2019-02-25 14:33:30
    当数组中每个元素都只带一个下标时,称这样的数组为一维数组一维数组实质上是一组相同类型数据的线性集合 举例:a(10),表示的就是a(0)到a(10)之间的十一组数据的集合,数据元素可以是数字,也可以是字符串。 ...

    一维数组的定义:
    当数组中每个元素都只带有一个下标时,称这样的数组为一维数组,一维数组实质上是一组相同类型数据的线性集合
    举例:a(10),表示的就是a(0)到a(10)之间的十一组数据的集合,数据元素可以是数字,也可以是字符串。
    二维数组的定义:
    二维数组本质上是以数组作为数组元素的数组,即“数组的数组”
    举例:a(2,2)
    他表示的数组集合为:
    a(0,0),a(0,1)a(0,2)
    a(1,0),a(1,1)a(1,2)
    a(2,0),a(2,1),a(2,2)
    共九组数据。
    注意:正常未做说明的情况下,数组的下标由0开始,当程序中有大量数组,需要统一下标时,在通用区编写option base 来制定数组下标

    展开全文
  • 一维数组转化为二维数组 使用场景举例:接口返回一个数组对象,展示时每行固定显示n个,则可将返回的数组转成二维数组[[...n], [...n]...]的形式循环展示。 分析:我们将一维数组,截取设定的长度,放入的一个新...

    一维数组转化为二维数组

    使用场景举例:接口返回一个数组对象,展示时每行固定显示n个,则可将返回的数组转成二维数组[[...n], [...n]...]的形式循环展示。

    分析:我们将一维数组,截取设定的长度,放入的一个新数组中。同时通过设定的长度,决定二维数组中的元素个数,但是一维数组的长度由总个数和设定的长度共同决定的。

    Math.floor

    floor() 方法返回小于等于x的最大整数。【向下取整】

    slice

    slice() 方法可从已有的数组中返回一个新的数组,包含从 start 到 end (不包括该元素)的元素。

    a.数组元素为基本类型:

    let baseArray = [1, 2, 3, 4, 5, 6, 7, 8];
    let len = baseArray.length;
    let n = 4; //假设每行显示4个
    let lineNum = len % 4 === 0 ? len / 4 : Math.floor( (len / 4) + 1 );
    let res = [];
    for (let i = 0; i < lineNum; i++) {
      // slice() 方法返回一个从开始到结束(不包括结束)选择的数组的一部分浅拷贝到一个新数组对象。且原始数组不会被修改。
      let temp = baseArray.slice(i*n, i*n+n);
      res.push(temp);
    }
    console.log(res);
    

    通过数组中index 和 设定长度 来建立一个新数组,iconsArr[0].push(item) 

    function arrTrans(num, arr) { // 一维数组转换为二维数组
      const iconsArr = []; // 声明数组
      arr.forEach((item, index) => {
        const page = Math.floor(index / num); // 计算该元素为第几个素组内
        if (!iconsArr[page]) { // 判断是否存在
          iconsArr[page] = [];
        }
        iconsArr[page].push(item);
      });
      return iconsArr;
    },

    b.数组元素为对象

    当数组元素为对象的时候,就不能使用slice方法进行截取了,因为slice属于浅拷贝,导致的问题就是你修改了新生成的数组对象值,会影响原始数组中对象的值,但很多时候我们并不想影响原来的值。

    深拷贝和浅拷贝主要是针对对象类型,基本类型并不涉及。

    let objArray = [{a: 1}, {b: 2}, {c: 3}, {d: 4}, {e: 5}, {f: 6}, {g: 7}];
    let len = objArray.length;
    let n = 4; //假设每行显示4个
    let lineNum = len % 4 === 0 ? len / 4 : Math.floor( (len / 4) + 1 );
    let res = [];
    for (let i = 0; i < lineNum; i++) {
    let temp = objArray.slice(i*n, i*n+n);
      res.push(JSON.parse(JSON.stringify(temp)));
    }
    console.log(res);
    

    二维数组转化为一维数组

    const arr=[[1,2,3],[3,4],[5]];
    console.log([].concat.apply([],arr));
    wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

    参考:js数组合并concat()和运用.apply()实现扁平化具体解析

    展开全文
  • 一维数组下标为index,二维数组长度为m * n,则: 一维数组转换为二维数组 row = index / n col = index % n 二维数组转换为一维数组 index = col + row * n

    设一维数组下标为index,二维数组长度为m * n,则:

    一维数组转换为二维数组

    row = index / n 
    col = index % n
    

    二维数组转换为一维数组

    index = col + row * n
    
    展开全文
  • C语言中一维数组与二维数组的比较

    万次阅读 2018-09-07 13:49:38
    C语言中一维数组与二维数组的比较: 从效率上讲: 一维数组访问一个数据时,只需要查找数组元素对应的地址,通过地址匹配到目标元素。 二维数组则需要先找到目标元素数组的地址,匹配到目标元素数组,然后再...
  • C#一维数组二维数组

    千次阅读 2017-07-28 11:04:23
    C#一维数组二维数组
  • a为二维数组名,此数组3行4列, 共12个元素。但也可这样来理解,数组a由三个元素组成:a[0], a[1], a[2]。而它们中每个元素又是一个一维数组, 且都含有4个 元素 (相当于4列),例如: a[0]
  • 一维数组是一条线 二维数组是一页纸 三维数组是一本书 四维数组是书架 五维数组是图书室2201(好几个书架) 六维数组是图书馆某一层,2楼/3楼,好几个图书室 七维数组是整个图书馆 第N维数组是...
  • JavaScript一维数组二维数组

    千次阅读 2018-12-26 10:02:50
    JavaScript一维数组二维数组 当接收到一个数组时后端不一定会给你做太多处理,而我们需要的是一个多维的数组,这个时候,我们就需要将一维数组进行转换 第一种情况:数组里面是字符串的时候 let array = [1, 2, 3...
  • C++ 动态申请二维数组与二维数组传参

    千次阅读 多人点赞 2018-12-15 11:59:41
    这样可以动态分配一个一维数组 但是如何动态分配一个二维数组呢?像这样: int **pa = new int[3][3] ?测试一次 => 显然这种分配方式是不正确的: 在尝试新的方法之前,我们需要首先了解二维数组在内存中...
  • Python输入数组(一维数组二维数组

    万次阅读 多人点赞 2018-08-09 20:14:34
    一维数组: arr = input("") //输入一个一维数组,每个数之间使空格隔开 num = [int(n) for n in arr.split()] //将输入每个数以空格键隔开做成数组 print(num) //打印数组 一维数组输入输出示例:  ...
  • 一维数组与二维数组题目练习

    千次阅读 2016-10-24 22:16:14
    标题:一维数组与二维数组题目练习 关键词:通过指针变量输入和输出一维数组,通过元素指针输入和输出二维数组。 内容:(A)输入数组,定义指针P指向数组第一个元素,即p=a或p=&a[0]。此刻p[i]等同于a[i]。...
  • 【C语言】一维数组二维数组

    千次阅读 2017-07-10 09:43:54
    一维数组二维数组
  • 一维数组二维数组

    千次阅读 2018-08-15 16:17:12
    在项目上,会遇到将一个一维数组的数据,按板块的分布排版这一类的需求。这种需求的数据往往就是数组元素中含有相同字段,以这相同字段分类即可达到需求。 以以下数据为例: 将 let oldArr= [ { name: "...
  • C经典 定义一维数组与二维数组

    千次阅读 2016-05-03 20:38:22
    #include <stdio.h>int main(int argc, const char * argv[]) { /** 位数组定义 char ch[10] = {'a','b','c'}; char ch[10] = "abc"; 二维数组定义 char chs[3][] = {{'a','b','c'},{'a','b','c'},
  • 因项目需要,要把两个一维的数组一一对应地转化为二维的,之后,在对合成的二维数组进行...//合并一维数组二维数组 function array_hebing(arr1,arr2){ var result = new Array(); for(var i=0;i;i++){ resu
  • js一维数组二维数组

    万次阅读 多人点赞 2018-05-24 13:47:27
    使用场景举例:接口返回个数组对象,展示时每行固定显示n个,则可将返回的数组转成二维数组[[...n], [...n]...]的形式循环展示。a.数组元素为基本类型: let baseArray = [1, 2, 3, 4, 5, 6, 7, 8]; len len = ...
  • 一维数组与二维数组深度解剖

    千次阅读 2015-12-16 01:04:45
    祥细分析一维数组与多维数组 1、首先我们来看一下一维数组 一维数组的定义:类型名 数组名[元素个数]  我们知道 编译器会在内存中会根据元素个数和元素数据类型分配一段连续的内存用来保存数据,每一个...
  • 1.一维数组 int arr[4]; 表示定义一个含有4个元素的一维数组,数组名为arr。 arr 数据类型为 整型的指针,相当于int *p; arr+1 相当于给一个指针+1,数据类型也为整型指针。 arr[0] 表示arr数组中的一个元素,数据...
  • 二维数组和嵌套数组的区别 [][]二维数组:数组可以不等长 [,]嵌套数组:数组必须等长 一维数组->二维数组[][] int[] a = { 1, 2, 3 }; int[] b = { 11, 22, 33,44}; int[][] ab = { a, b }; (参考链接:...
  • Java数组介绍(一维数组二维数组)1. 概述· 数组是存储多个变量的容器。· 存储的多个变量必须是同一种数据类型。· 数组既可以存储基本数据类型,也可以存储引用数据类型。2. 数组定义的格式· 格式1:数据...
  • 一维数组与二维数组名的差别

    千次阅读 2017-03-19 00:25:48
    一维数组名和二维数组名都可以看做是指针,不同在于: (1)一维数组名相当于指向该数组数据类型的指针; (2)二维数组名相当于指向该数组中的一维数组的数组指针。 比如,定义一维数组 int a[i] 和二维数组 int b...
  • 我定义 int num=20000; string[,] str2=new str[20,num]; for(int i=0;i;... 这里该怎么写,我要将str1放入str2[i, ]中,就是将20个一维数组组合成了二维数组,请求大神帮忙 }
  • JAVA 数组 一维数组二维数组

    千次阅读 2016-05-28 14:43:28
    一维数组知识点 // 定义一个a数组 int[] a = new int[]{3, 4 , 5, 6}; // 定义一个a2数组 int[] a2 = new int[]{3, 4 , 5, 6}; // a数组和a2数组的长度相等,每个元素依次相等,将输出true System.out.println("a...
  • 用new创建多维数组时,最后需要用delete,但是我在delete时遇到了麻烦,实在不能再浪费...一维数组 int a[4] ={1,2,3,4}; 二维数组 int b[3][4] = {1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4} 三维数组 int c[2][3][4] = {
  • 二维数组转为一维数组

    千次阅读 2016-11-12 11:28:21
    二维数组一维数组
  • 一维数组与二维数组之间的转换

    千次阅读 2018-08-26 20:12:21
    一维数组的下标Index(小标从0开始)和二维下标X、Y(下标从0开始)之间的转换公式: 一维到二维的转换:X = int ( Index / 9 ) Y = Index % 9  二维到一维的转换: Index = X * 9 + Y  (注意:这里是针对横...
  • 求大神指点java中一维数组二维数组区别,为什么一位数组是一行 二维数组可以定义多行

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 432,088
精华内容 172,835
关键字:

一维数组与二维数组有何区别