复盘:C语言中int a[][3]={1,2,3,4,5,6,7,8}什么意思?int a[3][]又是什么意思?结果为10的是?

提示:复盘牛客网的互联网大厂笔试题


文章目录

  • 复盘:C语言中int a[][3]={1,2,3,4,5,6,7,8}什么意思?int a[3][]又是什么意思?结果为10的是?
    • @[TOC](文章目录)
  • 题目
  • int a[][3]什么意思?意思是二维数组,列数为3,行数不固定,缺的补0
  • c语言中int a[3][]什么意思?
  • C 数组
  • C 多维数组
    • 二维数组
    • 以下能正确定义二维数组的是?B
  • 总结

题目

int a[][3]={1,2,3,4,5,6,7,8},哪个结果为10?


int a[][3]什么意思?意思是二维数组,列数为3,行数不固定,缺的补0

说白了就是3列卡死,你看看12345678怎么排???

本题就是:


c语言中int a[3][]什么意思?

这个语句试图定义一个拥有3行而列数不固定的二维数组,
但由于编译器要求多维数组的除最高维度外的每个维度都必须为已知量,因此事实上这句话不能通过编译。

行可以省略,但是不能省略。

int a[][3]合法,但int a[3][]不合法

C 数组

C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。
数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量

数组的声明并不是声明一个个单独的变量,
比如 runoob0、runoob1、…、runoob99,而是声明一个数组变量
比如 runoob,然后使用 runoob[0]、runoob[1]、…、runoob[99] 来代表一个个单独的变量。

所有的数组都是由连续的内存位置组成。
最低的地址对应第一个元素,最高的地址对应最后一个元素。

数组中的特定元素可以通过索引访问,第一个索引值为 0。

声明数组
在 C 中要声明一个数组,需要指定元素的类型和元素的数量,如下所示:

type arrayName [ arraySize ];

这叫做一维数组。
arraySize 必须是一个大于零的整数常量,type 可以是任意有效的 C 数据类型。
例如,要声明一个类型为 double 的包含 10 个元素的数组 balance,声明语句如下:

double balance[10];

现在 balance 是一个可用的数组,可以容纳 10 个类型为 double 的数字。

初始化数组
在 C 中,您可以逐个初始化数组,也可以使用一个初始化语句,如下所示:

double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0};

大括号 { } 之间的值的数目不能大于我们在数组声明时在方括号 [ ] 中指定的元素数目

如果您省略掉了数组的大小,数组的大小则为初始化时元素的个数。因此,如果:

double balance[] = {1000.0, 2.0, 3.4, 7.0, 50.0};

您将创建一个数组,它与前一个实例中所创建的数组是完全相同的。
下面是一个为数组中某个元素赋值的实例:

balance[4] = 50.0;

上述的语句把数组中第五个元素的值赋为 50.0。
所有的数组都是以 0 作为它们第一个元素的索引,也被称为基索引,
数组的最后一个索引是数组的总大小减去 1
以下是上面所讨论的数组的的图形表示:

下图是一个长度为 10 的数组,第一个元素的索引值为 0,第九个元素 runoob 的索引值为 8:

C 多维数组

C 语言支持多维数组。多维数组声明的一般形式如下:

type name[size1][size2]...[sizeN];

例如,下面的声明创建了一个三维 5 . 10 . 4 整型数组:

int threedim[5][10][4];

二维数组

多维数组最简单的形式是二维数组。
一个二维数组,在本质上,是一个一维数组的列表
声明一个 x 行 y 列的二维整型数组,形式如下:

type arrayName [ x ][ y ];

其中,type 可以是任意有效的 C 数据类型,
arrayName 是一个有效的 C 标识符。
一个二维数组可以被认为是一个带有 x 行和 y 列的表格。
下面是一个二维数组,包含 3 行和 4 列:

int x[3][4];


因此,数组中的每个元素是使用形式为 a[ i , j ] 的元素名称来标识的,其中 a 是数组名称,i 和 j 是唯一标识 a 中每个元素的下标。

初始化二维数组
多维数组可以通过在括号内为每行指定值来进行初始化。
下面是一个带有 3 行 4 列的数组。

int a[3][4] = {  {0, 1, 2, 3} ,   /*  初始化索引号为 0 的行 */{4, 5, 6, 7} ,   /*  初始化索引号为 1 的行 */{8, 9, 10, 11}   /*  初始化索引号为 2 的行 */
};

内部嵌套的括号是可选的,下面的初始化与上面是等同的:

int a[3][4] = {0,1,2,3,4,5,6,7,8,9,10,11};

访问二维数组元素
二维数组中的元素是通过使用下标(即数组的行索引和列索引)来访问的。例如:

int val = a[2][3];

以下能正确定义二维数组的是?B

A)int a[][3];——没有赋值,错误,知道是3列,但是多少行,不知道?
B)int a[][3]={2*3};——3列,有一个值6,剩下的补零就好,OK
C)int a[][3]={};——没有赋值,不对
D)int a[2][3]={{1},{2},{3,4}};——2行,3列,怎么赋值3行呢???


总结

提示:重要经验:

1)c语言的基础知识,经常在互联网大厂的笔试题中出现,这些八股文虽然考试那会你不知道,但是考完你需要复盘,好好学习
2)本题考的就是基本的数据类型的定义,c语言,可能还有c++,还有python,还有java啥的
3)笔试求AC,可以不考虑空间复杂度,但是面试既要考虑时间复杂度最优,也要考虑空间复杂度最优。

复盘:C语言中int a[][3]={1,2,3,4,5,6,7,8}什么意思,int a[3][]又是什么意思,结果为10的是相关推荐

  1. c语言double类型是几字节,c语言中int long float double 等类型所占字节及输出表示(转)...

    16位编译器 char :1个字节 char*(即指针变量): 2个字节 short int : 2个字节 int: 2个字节 unsigned int : 2个字节 float: 4个字节 doub ...

  2. c语言中c为字符型便量,c='97'是否正确,C语言判断题Word版

    <C语言判断题Word版>由会员分享,可在线阅读,更多相关<C语言判断题Word版(3页珍藏版)>请在人人文库网上搜索. 1.传播优秀Word版文档 ,希望对您有帮助,可双击去 ...

  3. putc函数_C语言中的putc()函数与示例

    putc函数 C语言中的putc()函数 (putc() function in C) The putc() function is defined in the <stdio.h> he ...

  4. fopen函数的用法示例_使用示例的C语言中的fopen()函数

    fopen函数的用法示例 C语言中的fopen()函数 (fopen() function in C) Prototype: 原型: FILE *fopen(const char* filename, ...

  5. n%i==0在c语言作用,在C语言中,if(n%i==0,)是什么意思?n和i分别为一个数、 , c语言中 if(n%i==0) break 什么意思...

    导航:网站首页 > 在C语言中,if(n%i==0,)是什么意思?n和i分别为一个数. , c语言中 if(n%i==0) break 什么意思 在C语言中,if(n%i==0,)是什么意思?n ...

  6. 在c语言中2 什么作用是什么,在C语言中23%7=2是什么意思

    在C语言中23%7=2是什么意思以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在C语言中23%7=2是什么意思 %是求 ...

  7. c语言putchar函数_C语言中的putchar()函数与示例

    c语言putchar函数 C语言中的putchar()函数 (putchar() function in C) The putchar() function is defined in the < ...

  8. c语言 while后面加,下面代码的C语言中while(x)是什么意思

    >while中文是什么意思 while n. 时间; 一段时间, 一会儿 wait a while. 等一会儿. it took a long while to do the work. 做这个 ...

  9. c语言中argc的作用,C语言中main函数的参数argc和argv

    参考资料: C++语言中的main函数,经常带有参数argc,argv,如下: int main(int argc, char** argv) int main(int argc, char* arg ...

  10. fwrite函数的用法示例_C语言中的fwrite()函数(带有示例)

    fwrite函数的用法示例 C中的fwrite()函数 (fwrite() function in C) Prototype: 原型: size_t fwrite(void *buffer, size ...

最新文章

  1. 区块链+5G=智慧城市?
  2. 免费课程 | 云脑机器学习实战训练营,中美大咖携手带你飞!
  3. OpenGL Multi-Indirect Draw小行星的实例
  4. TensorFlow学习笔记(十)tf搭建神经网络可视化结果
  5. TypeError: can‘t send non-None value to a just-started generator-python报错问题
  6. python使用opencv实现人脸识别系统
  7. 怎么样减少电脑对人的辐射
  8. [转]Using TRY...CATCH in Transact-SQL
  9. 最长公共子序列问题解析
  10. RK3128功能介绍
  11. PHP 生成 ppt,php在线编辑器fckedìtor应用.ppt
  12. 比较自然语言与计算机语言,计算机语言与自然语言的比较研究.pdf
  13. team多网卡绑定、桥接的搭建、tcpdump抓包
  14. PE新物种:从投基金到投管理机构,详解GP Stake-投资占股模式
  15. 支付宝小程序审核与发布
  16. 不会用苹果电脑(mac)的渣渣
  17. PHP电商运费模板,拼多多运费模板怎么设置?怎么使用运费模板?
  18. Android 修改默认的背景壁纸(msm8909)
  19. 云管边端架构图_边缘云平台架构与应用案例分析
  20. 百度语音识别极速版的使用例子(JAVA)

热门文章

  1. Docker执行命令提示设备没有相对空间,无法创建,overlay2文件夹磁盘占满
  2. # ** Error: ../tb/bfm/bfm_tb_ddr3/bfm_tb_ddr3.v(186): Illegal task output argument.
  3. 已知 XYZ+YZZ=532,其中,X、Y、Z 为数字,编程求出 X、Y 和 Z 的值
  4. asp.net 打印html文件,关于ASP.NET页面打印技术的常用方法总结
  5. 什么是GPU服务器?如何正确选择?
  6. everedit 格式化json_Bracket 使用指南
  7. 6 生僻字_教改后注音书还有必要读吗?别纠结,6-8岁注音书我推荐这10套
  8. python找出大写字母_在大写之前提取元素 - python
  9. java环境_linu安装jdk
  10. 新的GSMA报告强调“智联万物”在全球的作用