C语言高级教程-C语言数组(五):二维(多维)数组初始化和基于数组的综合实例->帽子选购问题_c语言新手编程程序二维数组的应用

printf("使用sizeof运算符求三维数组元素值的和为:%d\n", sum);

* 可以把numbers 数组看作一个 二维数组的数组。
* 表达式sizeof(numbers)得 到整个numbers数组占用的字节数,sizeof(numbers[0])得到二 维子数组占用的字节数,所以表达式sizeof(numbers)/sizeof(numbers[0])得到第一维中元素的个数。
* 同样,可以把每个二维子数组看作一维数组的一维数组。把二维数组的字节数除以其子数组的字节数,就会得到子数组的个数,它是numbers的第二维。
* 最后,把一维子数组的字节数除以一个元素的字节数,就得到第三维值。


### 5.2、sizeof运算符求数组元素值的和的运行结果



> 
> sizeof运算符求数组元素值的和的运行结果如下所示
> 
> 
> 


![在这里插入图片描述](https://img-blog.csdnimg.cn/aaf40bc69710407fb32319c78c64b089.jpeg#pic_center)


## 六、数组综合实例:帽子选购


![在这里插入图片描述](https://img-blog.csdnimg.cn/696aaafe94d6427f8097b8ee06808d3b.jpeg#pic_center)


### 6.1、问题描述



> 
> 数组综合实例:帽子选购的问题描述如下所示
> 
> 
> 


* 戴太大的帽子会很危险,它会遮住眼睛,使人撞到什么东西,导致受伤甚至死亡。
* 同样,戴太小的帽子会导致持续的头痛,让人看起来很愚蠢。本实例的程序将使用数组计算帽子的尺寸,其单位在美国和英国很常用,帽子尺寸一般是`6 1/2`到`7 7/8`。
* 对于本例的程序程序,只需输入帽子的周长(英寸),然后显示帽子的尺寸。


### 6.2、程序设计过程


### 6.2.1、用数组定义的帽子大小



> 
> 用数组定义的帽子大小 的代码如下所示
> 
> 
> 



// 用数组定义的帽子大小与字符相同
/\*

数组存储帽子的大小从6 1/2到7 7/8
每一行定义一个大小相同的字符
通过对三行使用相同的索引来选择大小。
例如索引2选择6又3/4。
*/
char size[3][12] =
{
{‘6’, ‘6’, ‘6’, ‘6’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’},
{‘1’, ‘5’, ‘3’, ‘7’, ’ ', ‘1’, ‘1’, ‘3’, ‘1’, ‘5’, ‘3’, ‘7’},
{‘2’, ‘8’, ‘4’, ‘8’, ’ ', ‘8’, ‘4’, ‘8’, ‘2’, ‘8’, ‘4’, ‘8’}
};

// 数值为1/8英寸
int headsize[12] =
{
    164,166,169,172,175,178,181,184,188,191,194,197
};

### 6.2.2、定义相关的变量



> 
> 定义相关的变量 的代码如下所示
> 
> 
> 



float cranium = 0.0;                // 头围,十进制英寸
int your_head = 0;                  // 头的八分之一
bool hat_found = false;             // 表示找到合适的帽子

### 6.2.3、输入头部的周长



> 
> 输入头部的周长 的代码如下所示
> 
> 
> 



// 输入头部的周长
printf("输入您的眉毛以上的头部周长,以英寸为十进制值: ");
scanf(" %f", &cranium);


your_head = (int)(8.0 \* cranium);      // 换算成八分之一英寸

### 6.2.4、搜索帽子的尺寸



> 
> 搜索帽子的尺寸 的代码如下所示
> 
> 
> 



 /\*

搜索帽子的尺寸:
要么你的头对应第一个头大小元素,要么你的头大于一个头大小元素,小于或等于下一个头大小元素。
在本例中,大小是第二个头大小值。
*/
unsigned int i = 0; // 循环计数器
if (your_head == headsize[i]) // 检查最小尺寸拟合
hat_found = true;
else
{
for (i = 1; i < 12; ++i)
{
// 在头部尺寸数组中查找头部尺寸
if (your_head > headsize[i - 1] && your_head <= headsize[i])
{
hat_found = true;
break;
}
}
}


### 6.2.5、输出探寻帽子的结果



> 
> 搜索帽子的尺寸 的代码如下所示
> 
> 
> 



// 输出探寻帽子的结果
if (hat_found)
    printf("\n你的帽子大小是 %c %c%c%c\n\n",size[0][i], size[1][i], (size[1][i] == ' ') ? ' ' : '/', size[2][i]);
// If no hat was found, the head is too small, or too large
else
{
    if (your_head < headsize[0])        // 检查是否太小
        printf("\n太小啦!你就是众所周知的针头。恐怕没有帽子给你了。\n\n");
    else                               // 它一定太大了
        printf("\n太大啦!用专业术语来说,你是个笨蛋。恐怕没有帽子给你了。\n\n");
}

### 6.3、程序运行结果



> 
> 数组综合实例:帽子选购的程序运行结果如下所示
> 
> 
> 


1. 帽子尺寸合适的运行结果  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20f7db072be74fb3bbe0f4c064af6af7.jpeg#pic_center)
2. 帽子尺寸太大的运行结果  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/5c5e799fe43a4ff9a4062dc8db3de6b9.jpeg#pic_center)
3. 帽子尺寸太小的运行结果  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/30a0e63fd96e406fa8dfaa6a62b8bbdb.jpeg#pic_center)


## 七、完整程序


![在这里插入图片描述](https://img-blog.csdnimg.cn/9a047c0af75a49a5a04196d046bb2808.jpeg#pic_center)



> 
> 本文的完整程序如下所示
> 
> 
> 


### 5.1 Main.h 文件程序



#ifndef MAIN_H
#define MAIN_H

#include <stdio.h>
#include <stdlib.h>

#endif


### 5.2 Main.c 文件程序



#define _CRT_SECURE_NO_WARNINGS

#include “Main.h”

int main()
{
system(“color 3E”);

// 二维数组的初始化
//int numbers[3][4] =
//{
// {10,20,30,40}, // 第一行的值 
// {15,25,35,45}, // 第二行的值 
// {47,48,49,50} // 第三行的值 
//};

//int numbers[3][4] = { 0 };

// 三维数组初始化
int numbers[2][3][4] = 
{
	{
		// 第一个块3行
		{10,20,30,40},
		{15,25,35,45},
		{47,48,49,50}
		},
		{
		// 第二个块3行
		{10,20,30,40},
		{15,25,35,45},
		{47,48,49,50}
	}
};



int sum = 0;

// 使用for循环求三维数组元素值的和
for (int i = 0; i < 2; i++)
{
	for (int j = 0; j < 3; j++)
	{
		for (int k = 0; k < 4; k++)
		{
			sum += numbers[i][j][k];
		}
	}
}

printf("使用for循环求三维数组元素值的和为:%d\n", sum);


// 使用sizeof运算符求三维数组元素值的和
sum = 0;
for (int i = 0; i < sizeof(numbers) / sizeof(numbers[0]); i++)
{
	for (int j = 0; j < sizeof(numbers[0]) / sizeof(numbers[0][0]); j++)
	{
		for (int k = 0; k < sizeof(numbers[0][0]) / sizeof(numbers[0][0][0]); k++)
		{
			sum += numbers[i][j][k];
		}
	}
}

printf("使用sizeof运算符求三维数组元素值的和为:%d\n", sum);

system("pause");
return 0;

}


### 5.3 Hat.h 文件程序



#ifndef HAT_H
#define HAT_H

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

#endif


### 5.4 Hat.c 文件程序



#define _CRT_SECURE_NO_WARNINGS

#include “Hat.h”

int main()
{
system(“color 3E”);

// 用数组定义的帽子大小与字符相同
/\*

数组存储帽子的大小从6 1/2到7 7/8
每一行定义一个大小相同的字符
通过对三行使用相同的索引来选择大小。
例如索引2选择6又3/4。
*/
char size[3][12] =
{
{‘6’, ‘6’, ‘6’, ‘6’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’, ‘7’},
{‘1’, ‘5’, ‘3’, ‘7’, ’ ', ‘1’, ‘1’, ‘3’, ‘1’, ‘5’, ‘3’, ‘7’},
{‘2’, ‘8’, ‘4’, ‘8’, ’ ', ‘8’, ‘4’, ‘8’, ‘2’, ‘8’, ‘4’, ‘8’}
};

// 数值为1/8英寸
int headsize[12] =
{
    164,166,169,172,175,178,181,184,188,191,194,197
};

float cranium = 0.0;                // 头围,十进制英寸
int your_head = 0;                  // 头的八分之一
bool hat_found = false;             // 表示找到合适的帽子

// 输入头部的周长
printf("输入您的眉毛以上的头部周长,以英寸为十进制值: ");
scanf(" %f", &cranium);


your_head = (int)(8.0 \* cranium);      // 换算成八分之一英寸

/\*

搜索帽子的尺寸:
要么你的头对应第一个头大小元素,要么你的头大于一个头大小元素,小于或等于下一个头大小元素。
在本例中,大小是第二个头大小值。
*/
unsigned int i = 0; // 循环计数器
if (your_head == headsize[i]) // 检查最小尺寸拟合
hat_found = true;
else
{
for (i = 1; i < 12; ++i)
{
// 在头部尺寸数组中查找头部尺寸
if (your_head > headsize[i - 1] && your_head <= headsize[i])
{
hat_found = true;
break;
}
}
}

// 输出探寻帽子的结果
if (hat_found)
    printf("\n你的帽子大小是 %c %c%c%c\n\n",size[0][i], size[1][i], (size[1][i] == ' ') ? ' ' : '/', size[2][i]);
// If no hat was found, the head is too small, or too large
else
{
    if (your_head < headsize[0])        // 检查是否太小
        printf("\n太小啦!你就是众所周知的针头。恐怕没有帽子给你了。\n\n");
    else                               // 它一定太大了
        printf("\n太大啦!用专业术语来说,你是个笨蛋。恐怕没有帽子给你了。\n\n");
}

system("pause");

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

// 它一定太大了
        printf("\n太大啦!用专业术语来说,你是个笨蛋。恐怕没有帽子给你了。\n\n");
}

system("pause");

[外链图片转存中…(img-B71L83Ug-1714699018775)]
[外链图片转存中…(img-sIuPv9zQ-1714699018775)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值