百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

一起学《C程序设计》第六课——数组、字符串及实战练习

yuyutoo 2025-03-04 14:57 3 浏览 0 评论

在之前的第三课中学习了基本数据类型,第五课学习了循环结构程序,做练习的时候处理的是一些有规律的数据,比如1~100的正整数,而当我们面对一堆没有规律的数据时该怎么去循环处理呢?把数据组合在一起构成一个新的数据结构,并且能利用自增的序号来循环引用它们,这就是数组。

注意,请认真学习完《C程序设计(第五版)》第六章后再阅读本文会有更大的收获。

C语言数组

数组

数组名和变量名

C语言数组命名遵从变量命名的规则,但是它们本质上有区别:变量名在程序里是该变量对应存储地址里存储的值;数组名等同于数组第一个元素的存储地址。

下标寻址

数组元素的使用采用数组名[下标]的形式,那它的原理是怎样的呢?

我们来深究一下数组内部元素是怎样存储的。首先,不管是数组名还是变量名,程序首先都会为它们开辟存储空间,分配一个存储地址;那么变量名的值就是这个存储地址里存储的值,数组名的值则是该数组第一个元素(下标0)的存储地址,这样就可以根据第一个元素的地址计算出第N个元素的存储地址(数组元素的地址是递增的),进而得到该存储地址里的值,也就是第N个元素的值。

元素数据类型统一

定义数组声明数据类型,实际上是元素的数据类型,一个数组里所有元素数据类型统一,好处就是在循环处理的时候都按照同一数据类型处理,不必额外做判断,这样省去不少麻烦。

多维数组

书本上介绍了二维数组,那如果把多个相同数据类型的二维 数组组合在一起,就构成了三维数组,同理,还有四维、五维……N维数组。

字符串

学习过其他高级语言的小伙伴在一开始会有点迷惑:字符串作为一种常见的数据形式居然没有定义在C语言的基本数据结构中,却介绍了字符char这种数据结构。原来在C语言中,字符串借助于字符数组,才有了一席生存的空间和施展的舞台。

C语言字符数组

注意,使用字符串相关的函数时,首先要引入头文件:#include

字符串输入和输出

输出指的是把字符数组输出为字符串的形式,常用printf('%s', str),和puts(str)。

书中的输入函数gets()在visual studio 2022中被强制要求使用gets_s()函数来代替,区别在于后者要指定字符数组的长度,而笔者推荐使用另外一个函数fgets(),至于他们有何区别又为何推荐使用fgets()大家自己写代码去对比分析以及上网查阅资料来加深理解。

字符串的长度

strlen()返回字符串自身的长度(以第一个\0为结尾但不包含\0),strlen("hello")和strlen("hello\0world")结果一样。

sizeof()返回的是字符数组的长度,字符数组一旦定义了,其长度就不会再变了。

字符串连接

与其叫字符串连接,不如称之为字符串合并/追加更直观。书上的strcat()函数在visual studio 2022推荐用strcat_s()来替代,这个函数多一个参数——字符串连接后的长度,这个是为了防止合并后的字符串过长(超出目标字符数组的长度)导致内存溢出,有兴趣的可以网上搜索相关的资料。

实战编程

回顾上一课输出1000以内完数,并且输出因子如6 its factors are 1,2,3

旧的思路:通过循环取因子相加判断出来完数,然后再循环输出因子,要写两次同样的循环。

优化思路:把第一次循环得到的因子存储在数组中,判断是完数之后再输出这个数组里的因子,代码参考:

static void fun() {
	for (int num = 1; num < 1000; num++) {
		int tmp_sum = 0, factor_index = 0;
		int factors[50] = { 0 };

		for (int i = 1; i < num; i++) {
			if (num % i == 0) {
				tmp_sum += i;
				factors[factor_index] = i;
				factor_index++;
			}
		}

		if (num == tmp_sum) {
			printf("%d its factors are ", num);
			for (int j = 0; j < factor_index; j++) {
				if (j < factor_index - 1) {
					printf("%d,", factors[j]);
				}
				else {
					printf("%d\n", factors[j]);
				}
			}
		}
	}
}

有一个已排好序的数组,要求输入一个数后,按原来排序的规则将它插入数组中。

解题关键有两点,一是找到插入的位置,然后要把后面的元素依次往后移动一个位置。我们以一个从小到大的数组为例进行编程:

static void fun4() {
	int arr_len = 11;
	int arr[11] = { 0,10,20,30,40,50,60,70,80,90,100 };
	int new_num;

	printf("请输入插入的数值:\n");
	scanf_s("%d", &new_num);

	int tmp_num = -10000, flag = 0;
	for (int i = 0; i < arr_len; i++)
	{
		int cur_num = arr[i];

		if (flag == 1) {
			arr[i] = tmp_num;
			tmp_num = cur_num;
			continue;
		}

		if (new_num <= cur_num) {
			flag = 1;
			tmp_num = cur_num;
			arr[i] = new_num;
		}

		if (flag == 0 && i == arr_len - 1) {
			arr[i] = new_num;
		}
	}

	for (int i = 0; i < arr_len; i++)
	{
		printf("%d ", arr[i]);
	}
}

程序里把找插入位置和元素后移的两个循环合成一个循环里面,一旦确定了插入位置之后,就不用再去判断找插入位置了,所以定义了一个flag标识,当flag为1时启用continue语句不执行后续的代码了。如果循环结束还没有找到插入的位置则说明插入的数比数组中任意数字都大,就让它直接替换数组末尾。

输出杨辉三角(10行)

解题思路的关键是找到规律:arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1]

static void fun6() {
	int rows = 10;
	int arr[10][10];

	for (int i = 0; i < rows; i++)
	{
		for (int j = 0; j < 10 j if j='= 0' i='= j)' arrij='1;' printf1\t continue if j> i) {
				arr[i][j] = 0;
				//printf("0\t");
				continue;
			}

			if (i > 1) {
				arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];
				printf("%d\t", arr[i][j]);
			}
		}
		printf("\n");
	}
}

总结

目前,我们的《C程序设计》课程已过半,通过程序练习可知,目前的知识能解决好多数学上的问题,进行一些较为复杂的程序设计。

不断的编程累积经验。一道题往往不止一种解法,要多去尝试,不仅尝试不同的算法,还要尝试用不同的数据结构、循环结构等C语言自身的语法特性来进行程序编码。

关于算法性的题目。目前比较好的学习方式是练习,去网站上刷题,把常见的经典算法题过一遍,慢慢地去积累。

逻辑向代码的转换。有的同学知道题目的解法,能用文字描述出来,但是就是不知道程序如何下手。比如今天学习的数组,一个简单的M行N列的二维数组,嵌套循环取值那里一时半会转不过来弯,总是觉得很“别扭”。

初学者的问题多而且千奇百怪,一定要坚持下来,多写多练,没有什么捷径可言。至于为何有的人学得快,而有的人却还没入门,笔者认为最重要的是兴趣。不要把程序看成是一行行冰冷的代码,经过不断地调试、修改后,程序运行出想要的结果时,相信你的嘴角一定是上扬的^_^

往期文章


一起学《C程序设计》第五课——循环控制及实战练习

一起学《C程序设计》第四课——if语句、switch语句及实战练习


一起学《C程序设计》第三课——数据结构、运算符、表达式和语句

一起学《C程序设计》第二课——算法


一起学《C程序设计》第一课——C语言概述和学习前的准备、意识

C程序设计(谭浩强)——第五版和第三版对比

相关推荐

像这样即能找勾又能打×的下拉菜单,您知道是怎么做的吗?

您知道像这样既能打勾又能打叉的下拉菜单怎么制作吗?比如这是一个考勤表,今天没有来,可以用叉看下拉菜单一个叉,然后这天到了打勾。怎么制作?·第一步,选中要制作的下拉菜单的单元格。·第二步,选择数据菜单里...

Axure教程:制作下拉选择框部件的联动效果

本文通过一个相对简单的示例,介绍了如何制作下拉选择框的联通效果。产品经理在制作产品原型的过程中,经常会遇到部件间联动的效果设计。如果不能通过原型交互方式来完成,则会以“静态页面+文字说明+步骤指引”的...

Excel技巧:最简单的制作下拉列表的方法

在制作报表的时候,经常会输入一些重复性的内容。这时候使用下拉列表直接选择,就可以简化重复输入的操作,不用费时费力地复制粘贴,同时录入信息页更加准确。示例图:操作步骤:...

下拉刷新之后,为什么我惊呆了?

2009年LorenBrichter在Tweetie2中首创了PullDowntoRefresh「下拉刷新」的交互方式,现在这一创举早已成为了各种Feed类应用的标准配置。虽...

每天进步一点点——excel如何设置下拉选项

excel在数据录入的时候,有时候为了方便,不逐条手打,我们常会设置一个下拉选项,直接进行选择。比如性别的录入,就可以偷懒,直接手动选择,比一个个打字要快。最简单下拉选项(以录入性别为例子)第一步,我...

EXCEL表格常用 下拉序号的三种方法 三分钟学会这些方法 详细教程

下拉序号三种方法做表格输入序列号是常有的事,正因为经常输入,我们不好一个一个的去输入,那样太累了。假如有100个序号,我们从一输入到100,会很累的。下面我们学习一下三种输入序号的方法:...

3种方法教你制作Excel中“下拉菜单”

在Excel中,我们经常会面对有很多的数据需要录入,尤其是一些重复的数据。那如何才能解决这个令我们头疼的问题呢,这就是我今天要介绍的下拉菜单的制作。...

表格自动新增下拉选项,Ctrl+T解决重复设置难题,80%人都碰到过

为了方便进行数据输入、汇总及统计,规范我们的Excel表格格式,我们在工作中经常会对单元格进行数据有效性设置,这样可以限定单元格根据下拉选项进行填写内容,让大家按照统一的规范进行输入。如上图所示,我们...

Excel制作搜索式下拉菜单,1条公式,2步搞定

下拉菜单在数据录入的时候,可以提升工作效率,但是如果下拉菜单数据太多的时候,也不好进行选择,我们可以制作成可以搜索的下拉菜单,先输入一个关键字,然后再次进行选择效果如下所示:制作的方法其实很简单,只需...

快速下拉,特别适用于要拉的手断的那种大量数据情况。

办公小技巧:制作更炫酷的Excel下拉菜单

在Excel中制作下拉菜单,大都是利用数据有效性,再有就是表单控件中的组合框。数据有效性或表单控件组合框制作下拉菜单,快捷、便利、实用、功能很全面,但也有力所不及的地方,比如设置下拉菜单的字体、颜色、...

Excel制作智能模糊搜索下拉菜单,1条公式搞定

我们有一列数据,想制作成下拉菜单,然后输入部分关键字,就可以模糊搜索符合条件的值,提供对应的下拉菜单供我们选择,效果如下所示:1、WPS中的EXCELWPS关于下拉菜单,已经做到了智能搜索,所以只需要...

负面下拉词:深入解析与应对策略

你要写负面下拉词,就不能只写负面下拉词。要写信息时代的暗流涌动,数据洪流中潜藏的危机与机遇;要写算法逻辑的冷酷无情,如何在用户行为与数据驱动下,悄然形成负面印象的漩涡;要写品牌与个人的挣扎与抗争,如何...

制作Excel下拉菜单,源数据更新,无需重新设置

在做表格数据录入工作的时候,一方面需要提升数据录入的效率,也需要防止数据录入出错,因此我们会对数据区域设置下拉菜单,从下拉选项中选择我们需要的数据进行录入1、下拉菜单基本设置首先我们要准备下拉菜单的数...

制作2级联动下拉菜单,1分钟搞定,快来学吧!

数据录入的时候,经常需要用到两级下拉菜单,并且需要联动,输入完第一级内容之后,第二级的内容是对应的效果如下所示:制作过程也非常简单,只需要几步就可以完成1、准备数据源第一行中的数据,输入一级下拉菜单中...

取消回复欢迎 发表评论: