C语言初阶作业题-数组

一、选择题

1.关于一维数组初始化,下面哪个定义是错误的?( )

A.int arr[10] = {1,2,3,4,5,6};
B.int arr[] = {1,2,3,4,5,6};
C.int arr[] = (1,2,3,4,5,6);
D.int arr[10] = {0};

答案解析:
A:正确,10个int的一段连续空间,前6个位置被初始化为1,2,3,4,5,6,其他位置为0
B:正确,数组中有6个空间,并被初始化为1,2,3,4,5,6
C:错误,数组的初始化不能使用(),只能使用{}
D:正确,10个int类型的一段连续空间,每个位置都被初始化为0
因此,选择C

2.定义了一维 int 型数组 a[10] 后,下面错误的引用是:( )

A.a[0] = 1;
B.a[0] = 5*2;
C.a[10] = 2;
D.a[1] = a[2] * a[0];

答案解析:
数组是相同类型的一段连续的空间,下标是从0开始的,比如:int array[N]
下标的范围为[0,N),其中N位置不能存储有效元素
A:正确,将0号位置设置为1
B:正确,将0号位置设置为10
C:错误,越界
D:正确,1号位置初始化为a[2]*a[0]之后的结果
因此,选择C

3.若定义int a[2][3]={1,2,3,4,5,6};则值为4的数组元素是( )

A.a[0][0]
B.a[1][0]
C.a[1][1]
D.a[2][1]

答案解析:
int a[2][3]表示2行3类的二维数组,根据其初始化知:
第0行即a[0]存储3个元素: 1,2,3
第1行即a[1]存储3个元素: 4,5,6
因此值为4的元素在第1行第0列
因此,选择B

4.下面代码的结果是:( )

#include <stdio.h>
int main()
{int arr[] = {1,2,(3,4),5};printf("%d\n", sizeof(arr));return 0;
}

A.4
B.16
C.20
D.5

答案解析
对于int arr[] = {1,2,(3,4),5}数组,里面总共有4个元素,(3,4)为逗号表达式,取后者,因此数组中元素分别为:1,2,4,5
而sizeof(arr)求的是整个数组所占空间的大小,即:4sizeof(int)=44=16
因此,选择B

5.下面代码的结果是:( )

#include <stdio.h>
int main()
{char str[] = "hello bit";printf("%d %d\n", sizeof(str), strlen(str));return 0;
}

A.10 9
B.9 9
C.10 10
D.9 10

答案解析:
str字符数组使用"hello bit"初始化,最终也会将’\0’放置到数组中,因此数组中总共有10个元素
sizeof(str):获取数组的总大小,10个元素,每个元素占1个字节,因此总共是10个字节
strlen(str): 获取字符串中有效字符的个数,不算’\0’,因此总共9个有效字符
故上述printf会分别打印:10 9
因此,选择A

6.给出以下定义:

char acX[] = “abcdefg”;
char acY[] = {‘a’,’b’,’c’,’d’,’e’,’f’,’g’};

以下说法正确的是( )

A.数组acX和数组acY等价
B.数组acX和数组acY的长度相同
C.数组acX的长度大于数组acY的长度
D.数组acX的长度小于数组acY的长度

答案解析:
acX和acY都是字符数组,但是初始化表达式不同,acX和acY的区别如下:
acX:数组中总共有8个元素,分别是:‘a’,‘b’,‘c’,‘d’,‘e’,‘f’,‘g’,’\0’
acY:数组中总共有7个元素,分别是:‘a’,‘b’,‘c’,‘d’,‘e’,‘f’,‘g’
因此,选择C

7.关于一维数组描述不正确的是:( )

A.数组的下标是从0开始的
B.数组在内存中是连续存放的
C.数组名表示首元素的地址
D.随着数组下标的由小到大,地址由高到低

答案解析:
A:正确,C语言规定,数组的下标是从0开始的
B:正确,数组的空间是一段连续的内存空间
C:正确,数组名既可以表示数组的地址,也可以表示数组首元素的地址,两个在数值上是一样的,但是含义不一样。
注意:数组名只有在sizeof和&后才代表整个数组,其它都表示首元素的地址
D:错误,这个要是系统而定,一般都是下标由小到大,地址由低到高
因此,选择D

8.以下能对二维数组a进行正确初始化的语句是:( )

A.int a[2][]={{0,1,2},{3,4,5}};
B.int a[][3]={{0,1,2},{3,4,5}};
C.int a[2][4]={{0,1,2},{3,4},{5}};
D.int a[][3]={{0,2},{},{3,4,5}};

答案解析
对于二维数组int array[M][N], 说明如下:

  1. M和N都必须为常数,
  2. M代表数组有M行,N代表每行中有N个元素
  3. 其中M可以省略,省略后必须给出初始化表达式,编译器从初始化结果中推断数组有多少行
  4. N一定不能省略,因为N省略了就不能确定一行有多少个元素,也不能确定数组有多少行
    A:错误,参数上述说明
    B:正确,参考上述说明
    C:错误,数组有两行,但是初始化给了三行
    D:错误,初始化不允许{0,2}该种情况存在
    因此,选择B

二、编程题

1.实现一个对整形数组的冒泡排序

/*
思路:
遍历数组,对数组中相邻的两个元素进行比较,如果需要升序,前一个数据大于后一个数据时,交换两个位置上的数据,直到所有的数据比较完,此时,最大的数据已经放在数组的末尾。
除最大数据已经排好序外,其余数据还是无需,对剩余数据采用与上述类似的方式进行处理即可
*/void BubbleSort(int array[], int size)
{// 外层循环控制冒泡排序的趟数// size-1表示:最后一趟区间中只剩余1个元素,该趟冒泡可以省略for(int i = 0; i < size-1; ++i){// 具体冒泡的方式:用相邻的两个元素进行比较,前一个大于后一个元素时,交换着两个数据,依次直到数组的末尾for(int j = 1; j < size-i; ++j){if(array[j-1] > array[j]){int temp = array[j-1];array[j-1] = array[j];array[j] = temp;}}}
}/*
优化:如果某次冒泡结束后,序列已经有序了,后面剩余元素的冒泡可以省略
*/void BubbleSort(int array[], int size)
{// 外层循环控制冒泡排序的趟数// size-1表示:最后一趟区间中只剩余1个元素,该趟冒泡可以省略for(int i = 0; i < size-1; ++i){int isChange = 0; // 具体冒泡的方式:用相邻的两个元素进行比较,前一个大于后一个元素时,交换着两个数据,依次直到数组的末尾for(int j = 1; j < size-i; ++j){if(array[j-1] > array[j]){int temp = array[j-1];array[j-1] = array[j];array[j] = temp;isChange = 1;   // 如果本次冒泡进行数据交换了,说明本次还是无序的,就将isChange设置为1}}// 如果本次冒泡中,元素没有交换,则本次开始冒泡时,数据已经有序了,后面的冒泡可以不用进行了if(!isChange)return;}
}

2.创建一个整形数组,完成对数组的操作

1.实现函数init() 初始化数组为全0
2.实现print()  打印数组的每个元素
3.实现reverse()  函数完成数组元素的逆置。

要求:自己设计以上函数的参数,返回值。

/*
思路:函数比较简单,请参考实现
*/void Init(int arr[], int sz, int set)
{int i = 0;for(i=0; i<sz; i++){arr[i] = set;}
}void Print(int arr[], int sz)
{int i = 0;for(i=0; i<sz; i++){printf("%d ", arr[i]);}printf("\n");
}void Reverse(int arr[], int sz)
{int left = 0;int right = sz-1;while(left<right){int tmp = arr[left];arr[left] = arr[right];arr[right] = tmp;left++;right--;}
}

3.将数组A中的内容和数组B中的内容进行交换。(数组一样大)

*
思路:题目比较简单,请参考代码以及注释
*/#include <stdio.h>int main()
{int arr1[10] = {0};int arr2[10] = {0};int i = 0;printf("请输入10个数字:>");for(i=0; i<10; i++){scanf("%d", &arr1[i]);}printf("请输入10个数字:>");for(i=0; i<10; i++){scanf("%d", &arr2[i]);}//交换for(i=0; i<10; i++){int tmp = arr1[i];arr1[i] = arr2[i];arr2[i] = tmp;}return 0;
}

C语言初阶作业题-数组相关推荐

  1. C语言初阶(18) | 数组详解

    目录 1.数组的定义 2.一维数组 2.1一维数组的格式 2.2一维数组的初始化 2.3一维数组的使用 2.4一维数组再内存中的存储 3.二维数组 3.1二维数组的创建和初始化 3.2二维数组的使用 ...

  2. C语言初阶_初识C语言(1)

    凡是过往,皆为序章 期末考试结束了,真是感慨良多啊...... C语言编程题大家都做对了多少呢? 不管怎么样,都已经过去了.不管你学得怎么样,都可以在接下来的时间里,我们一起重新回顾一遍C语言初阶的知 ...

  3. C语言初阶——5.字符串

    C语言初阶--5.字符串 1. 字符串操作 1.1 字符串遍历 可以通过数组方式遍历字符串. char* str="Hello World"; for(int i = 0;'\0' ...

  4. 五十分钟带你看遍C语言初阶语法(总纲)

    C语言初阶语法(总纲) 此篇博客包含了前面C语言所有的基础语法,写这一期的博客不仅是为了记录自己的学习成果也是为了让更多的朋友能学到对自己有用的知识,如果总有一个知识点帮助到了你,给卑微博主点点关注加 ...

  5. C语言初阶——6.进制

    C语言初阶--6.进制 1. 进制 百度百科: 进制也就是进位计数制,是人为定义的带进位的计数方法,对于任何一种进制-X进制,就表示每一位置上的数运算时都是逢X进一位. 十进制是逢十进一,十六进制是逢 ...

  6. C语言初阶总结 v1

    目录 C 基础1⭐ 数据类型 计算机中的单位 常量与变量 字符串/转意字符/ 注释 C 基础2⭐ 判断语句 函数与数组 C语言操作符 C语言关键字 C语言定义宏与关键字 初始指针 ⭐⭐ 指针基础 拓展 ...

  7. C语言初阶第三篇:换我心,为你心,始知C语言 从C语言选择语句到循环语句保姆教学来喽

    换我心,为你心,始知C语言 老铁们,咱们上一篇文章把字符串的知识点给过了一遍,今天就要开始真正的程序语句的学习了,也就是选择语句和循环语句,今天的内容比较简单,所以写的也不多,废话不多说,咱们开始吧! ...

  8. 《C语言初阶进阶完整教程》- 已完结 - qsort函数使用方法+(数组,结构体,手动实现函数)

    目录 前言 一.解释qsort函数 1.函数原型 2.深度解析comper比较函数 二.函数使用 1.int 2.结构体 三.手动实现函数 2.核心代码(两段) 四.升级使用方法 前言 提示:此文章可 ...

  9. C语言初阶第二篇:换我心,为你心,始知C语言 从程序调试到全网最详细字符串教学来喽

    换我心,为你心,始知C语言 老铁们,我们这个系列的上一篇文章讲到了变量常量,那么今天我们就继续说一说之后的一些知识框架,保证零基础也能看懂,废话不多说,我们开始吧! 第二篇 一.探讨字符串 二.插入知 ...

最新文章

  1. 模板 - 欧拉路、欧拉回路(一笔画问题)
  2. The Innovation | Call for Youth Editors 青年编委招募
  3. java 文件写入 读取_JAVA文件的两种读取方法和三种写入方法
  4. Linux防止ARP攻击的一些方法
  5. 支付宝支付回调异常_支付宝崩了是怎么回事 支付宝崩了部分用户使用异常现已恢复...
  6. 笔记-中项案例题-2019年下-信息系统安全管理
  7. 定义范围中的备选方案生成、横向思维、创建WBS、工作包定义、WBS、确认范围过程和实施质量过程的关系、联合应用设计和质量功能展开QFD
  8. 【重磅直播预告】IDC提效分享
  9. 使用LeakTracer检测android NDK C/C++代码中的memory leak
  10. 【简便解法】1035 插入与归并 (25分)_37行代码AC
  11. rxjs里scan operators的用法
  12. Java的加载与执行
  13. 【ElasticSearch】 Hive数据导入到 es 的 项目 FastIndex
  14. 介绍Ext JS 4.2的新特性的《深入浅出Ext JS》上市
  15. 红警 1 游戏开源,代码非常规范,网友:秀色可餐
  16. springboot上传文件到resources_SpringBoot进行文件上传(一)
  17. linux pci带宽,Linux查看PCIe版本及速率
  18. 如何更改IDEA的主题(背景黑色还是白色)
  19. 添加Extension库
  20. 机器人的核心——运动控制器

热门文章

  1. Linux中chown、chmod、chgrp的区别和用法
  2. 三本计算机的专业需要考研嘛,三本计算机考研难吗
  3. 杰里之AI(692X系列)篇
  4. 计算机毕业设计Java某日杂商店进销存管理系统设计(源码+系统+mysql数据库+lw文档)
  5. 我对社交电商的了解与看法
  6. matlab 双均线,我的双级别双重均线系统的建立初探
  7. 指纹识别综述(2): 指纹传感器
  8. prev_permutation 函数
  9. 重学设计模式 - Facade模式
  10. PL读写DDR3 实现PS和PL间的数据交互