精华内容
下载资源
问答
  • 二维数组也是一个一维数组,每个元素都是一个一维数组。初学数组,我认为画图最能帮助我理解,一看就明白,之后再向怎么去写程序,在一步一步调试程序,直到完成。
    #include <stdio.h>
    int main()
    {
    int i;
    int j;
    int a[3][4] = {3,16,87,65,4,32,11,108,10,25,12,37};
    int b[3];
    for(i = 0;i < 3;i++)
    {
    	b[i] = 0;     //b[i]在下面循环赋值之后要清零,继续以 0 进行下一次循环,找最大值
    	for(j = 0;j < 4;j++)
    	{
    		if(b[i] < a[i][j])
    		{
    			b[i] = a[i][j];
    		}
    	}
    }
    	for(j = 0;j < 3;j++)
    	{
    		printf("%d",b[j]);
    	}
    	printf("\n");
    
    	return 0;
    }

    展开全文
  • 输入:二维数组array、一维数组element 功能:判断array是否包含element 输出:true/false 本想着用Array.indexOf,但是数组在内存中是以引用的方式存在的,想要比较两个数组是否相等,是不可以使用 a === b 来...

    输入:二维数组array、一维数组element

    功能:判断array是否包含element

    输出:true/false


    本想着用Array.indexOf,但是数组在内存中是以引用的方式存在的,想要比较两个数组是否相等,是不可以使用 a === b 来判断的。因为数组 a 和数组 b 本身的值都是数组的地址。

    因此必须遍历array中的每个元素,来判断是否有元素与element相等。 

    对于两个数组是否相等,只能采用对数组的每个元素逐个判断是否相等,所有元素都相等,才能说这两个数组相等。

    /**
     * @param {number[][]} array
     * @param {number[]} element
     * @return {boolean}
     */
    var arrayHasElement = function(array, element) {  // 判断二维数组array中是否存在一维数组element
      for (var el of array) {
        if (el.length === element.length) {
          for (var index in el) {
            if (el[index] !== element[index]) {
              break;
            }
            if (index == (el.length - 1)) {    // 到最后一个元素都没有出现不相等,就说明这两个数组相等。
              return true;
            }
          }
        }
      }
      return false;
    }

     

    展开全文
  • 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’在内
    在这里插入图片描述

    展开全文
  • 输入一个二维数组,求二维数组中各元素的和。 #include<iostream> using namespace std; int main() { int math[3][4],sum1,sum2; int i,j; cout<<"请输入数组元素:"<<endl; for(i=0;i<3...

    输入一个二维数组,求二维数组中各行元素的和。

    #include<iostream>
    using namespace std;
    int main()
    {
    	int math[3][4],sum1,sum2;
    	int i,j;
    	cout<<"请输入数组元素:"<<endl;
    	for(i=0;i<3;i++)
    	{
    		for(j=0;j<4;j++)
    		{
    			cin>>math[i][j];
    		}
    	}
    	for(i=0;i<3;i++)
    	{
    		sum1=0;
    		for(j=0;j<4;j++)
    		{
    			sum1+=math[i][j];
    		}
    		cout<<"第"<<i<<"行的,元素和为:"<<sum1<<endl;
    	}
    	cout<<endl;
    	for(j=0;j<4;j++)
    	{
    		sum2=0;
    		for(i=0;i<3;i++)
    		{
    			sum2+=math[i][j];
    
    		}
    		cout<<"第"<<j<<"列的,元素和为:"<<sum2<<endl;
    	}
    	return 0;
    }
    
    展开全文
  • var arrayHasElement = function(array, element) { // 判断二维数组array中是否存在一维数组element for (var el of array) { if (el.length === element.length) { for (var in...
  • 二维数组二维数组

    千次阅读 2018-06-26 05:50:40
    那么二维数组在内存中又是怎么存储的,其数组名又什么含义呢?   定义一个二维数组: int arr   [3] [4] = {{1,1,1,1},{2,2,2,2},{3,3,3,3},{4,4,4,4}};   我们可以将一个二维数组看做是一个其中元素...
  • java中如何判断二维数组是否为空

    千次阅读 2018-04-29 16:56:14
    在Java程序设计里面,相信大部分人都知道如何判断一个一维数组是否为空,示例如下:public ... 那么在二维数组中,又如何判断二维数组为空呢?在判断之前,我们要先了解如何获取二维数组的行数和列数,示例如下:...
  • 二维数组是一页纸 三维数组是一本书 四维数组是书架 五维数组是图书室2201(好几个书架) 六维数组是图书馆某一层,2楼/3楼,好几个图书室 七维数组是整个图书馆 第N维数组是宇宙...................
  • 二维数组的结构决定了其能非常方便地表示计算机中的表,以第一个下标表示元素所在的,第二个下标表示元素所在的列。下面简单了解一下二维数组,包括数组的声明和初始化。 创建二维数组 在 Java 中二维数组被看作...
  • 如题:C++中怎么将一维数组输出为二维数组,比如一维数组(1.2.3.4…100),输出为520列的二维数组 已调试,正常输出。 ** #include using namespace std; int main() { int iArr[100]={};//声明一维...
  • C++ 动态申请二维数组二维数组传参

    千次阅读 多人点赞 2018-12-15 11:59:41
    但是如何动态分配一个二维数组呢?像这样: int **pa = new int[3][3] ?测试一次 => 显然这种分配方式是不正确的: 在尝试新的方法之前,我们需要首先了解二维数组在内存中的存储结构: ...
  • 二维数组既可以通过二维访问也可以通过一维访问。 对于二维数组的传值,引进了数组指针。 #include void foo(int *p,int n)//一维访问 { for(int i=0;i;i++) printf("%d ",p[i]); printf("\n"); } //因为...
  • 静态二维数组和动态二维数组(C语言)

    千次阅读 多人点赞 2017-04-09 12:31:34
    静态二维数组:可以理解为程序中如下定义的数组(定义一个34列的静态二维数组) int [3][4] = {{1,1,1,1}, {2,2,2,2}, {4,4,4,4}}; 动态二维数组:可以理解为程序中如下定义的数组(定义一个34列的动态二维...
  • 二维数组每一分别排序

    千次阅读 2019-11-22 11:48:55
    要求:对二维数组的奇偶分别进行升序和降序排序,要求用函数实现。 主要代码: #include <stdio.h> void sort_array(int a[], int n, char c); void print_array(int a[][5], int n); int main() { int i; ...
  • C语言指针重点难点整理(详解)(包括一维数组,二维数组的元素指针,二维数组指针做函数参数,指针数组,指针数组) 笔者学指针之前: 呵呵,听闻指针是C语言的难点,我倒要见识一下,到底多难 笔者学完...
  • 二维数组

    千次阅读 多人点赞 2019-09-15 23:09:15
    二维数组 二维数组的定义 格式: int[][] arr = new int[3][4]; 定义一个二维数组,这个数组是由3个一维数组组成,每个一维数组的长度是4; 也就是说,上面这个二维数组存储了12个数据 System.out.println(arr);这个...
  • #include #include //二维数组赋值 void show2() { int a[3][4]; int k=0; for(int i=0;i;i++) { for(int j=0;j;j++) { a[i][j]=i*4+(j+1);//数学公式 赋值 // a[i
  • php判断二维数组中是否含有某个值 $arr = array(  array('a', 'b'),  array('c', 'd') ); in_array('a', $arr); // 此时返回的永远都是 false deep_in_array('a', $arr); // 此时返回 true 值 function deep_...
  • 二维数组及遍历

    万次阅读 多人点赞 2019-09-12 17:41:23
    二维数组及遍历 概念 初始化方式详解 遍历 我在前面的博文详细说过一维数组的概念初始化方式及遍历,今天这篇博文,可以看过前面博文的会很容易接受,前置博文,请直接点击链接跳转。 什么是二维数组二维数组和...
  • 判断二维数组中是否存在某值?

    千次阅读 2019-09-16 23:59:59
    在一个二维数组中(每个一维数组的长度相同),每一都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 思路: ...
  • 二维数组转为一维数组

    千次阅读 2016-11-12 11:28:21
    二维数组转一维数组
  • 因项目需要,要把两个一维的数组一一对应地转化为二维的,之后,在对合成的二维数组进行排序,从而实现一一对应的排序 合并函数: //合并一维数组为二维数组 function array_hebing(arr1,arr2){ var result = ...
  • java二维数组字符数组Today we will look into Two-dimensional array in java. An array is like a container that can hold a certain number of values. 今天,我们将研究Java中的二维数组。 数组就像可以容纳...
  • 关于用指针方式访问二维数组的问题 首先说明几种类型: int a[2][4] = { 1,2,3,4,5,6,7,8 };//二维数组 int **p; //二重指针跨度为sizeof(int *) int(*q)[4]; //该语句是定义一个指向数组的指针,指向含4个...
  • java 二维数组 为什么不可以省略

    千次阅读 2019-10-08 20:18:49
    数组的长度是固定的使用前必须指定长度, 二维数组的长度就是二维数组有x,则该二维数组的长度是x int[][] arr = new int[10][]; System.out.println(arr.length);//10 ...
  • C#二维数组拷贝到另一个二维数组

    千次阅读 2017-08-22 17:38:38
    网上找了下,没有找到关于二维数组拷贝到二维数组的相关内容。Array.Copy的使用方法中一般给的例子是一维数组。这里解释一种拷贝二维数组的方法,使用的仍然是Array.Copy的方法。 如下数组: a=[1 2 3 4; 5 6 7 8;...
  • java的二维数组和C语言二维数组的储存结构什么区别?,数据结构什么区别吗?人说java的数组在内存中存储不是连续的,,
  • 请使用你熟悉的语言实现一个函数 reshape,输入参数是一个二维数组 matrix、整数 M 和 N ,将这个二维数组重新排列成 M N 列的二维数组。例如 reshape([[1, 2, 3], [4, 5, 6]], 3, 2) 应返回 [[1, 2], [3, 4], [5...
  • PHP 判断二维数组中是否含有某个值

    千次阅读 2019-10-13 03:25:37
    主要是因为用mysqli_fetch_all() 这函数返回的数组是数字索引的二维数组时候我们需要判断一个主键是否在这个二维数组中就会遇到一些麻烦,常见的做法就是写循环判断,但是如果需要判断多次的情况下,我们循环...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 462,962
精华内容 185,184
关键字:

如何判断二维数组有多少行