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

news2024/11/20 9:48:20

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

  • 一、本文的编译环境
  • 二、二维数组的初始化
  • 三、三维数组的初始化
  • 四、使用for循环求三维数组元素值的和
    • 4.1、for循环求数组元素值的和
    • 4.2、for循环求数组元素值的和的运行结果
  • 五、使用sizeof运算符求三维数组元素值的和
    • 5.1、sizeof运算符求数组元素值的和
    • 5.2、sizeof运算符求数组元素值的和的运行结果
  • 六、数组综合实例:帽子选购
    • 6.1、问题描述
    • 6.2、程序设计过程
    • 6.2.1、用数组定义的帽子大小
    • 6.2.2、定义相关的变量
    • 6.2.3、输入头部的周长
    • 6.2.4、搜索帽子的尺寸
    • 6.2.5、输出探寻帽子的结果
    • 6.3、程序运行结果
  • 七、完整程序
    • 5.1 Main.h 文件程序
    • 5.2 Main.c 文件程序
    • 5.3 Hat.h 文件程序
    • 5.4 Hat.c 文件程序
  • 八、总结

在这里插入图片描述

一、本文的编译环境

本文的编译环境使用的是集成开发环境:Visual Studio 2019
在这里插入图片描述

Visual Studio 2019官网链接如下

Visual Studio 2019官网链接
在这里插入图片描述

Visual Studio 2019集成的开发环境的特点有

  • Visual Studio 2019默认安装Live Share代码协作服务。
  • 帮助用户快速编写代码的新欢迎窗口、改进搜索功能、总体性能改进。
  • Visual Studio IntelliCode AI帮助。
  • 更好的Python虚拟和Conda支持。
  • 以及对包括WinForms和WPF在内的.NET Core 3.0项目支持等 。

二、二维数组的初始化

  • 二维数组的初始化类似于一维数组。
  • 区别是把每一行的初始值放在大括号{}中,再把所有行放在一对大括号中。
	// 二维数组的初始化
	int numbers[3][4] =
	{
		{10,20,30,40}, // 第一行的值 
		{15,25,35,45}, // 第二行的值 
		{47,48,49,50}  // 第三行的值 
	};
  • 初始化行中元素的每组值放在大括号中,所有的初始值则放在另一对大括号中。一行中的值以逗号分开,各行值也需要以逗号分开。
  • 如果指定的初值少于一行的元素数,这些值会从每行的第-一个 元素开始,依序赋予各元素,剩下未指定初值的元素则初始化为0。

仅提供-一个值,就可以把整个数组初始化为0:

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

三、三维数组的初始化

  • 三维数组是二维数组的扩展。
  • 三维数组的初始化有3级嵌套的括号。
  • 内层的括号包含每行的初始值。

三维数组的初始化如下所示

// 三维数组初始化
	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}
		}
	};
  • 可以看到,初始化的值放在一一个外层的大括号中,该外层括号由两个包含3行的块组成,每个块也放在括号中,各个块中的每-行也放在括号中,所以三维数组有3层嵌套括号。
  • 一般来说是这样的,例如六维数组用6层嵌套括号包含元素的初始值。可以省
    略每一行的括号, 但给每一行的值加上括号比较安全,因为更不容易出错。

四、使用for循环求三维数组元素值的和

4.1、for循环求数组元素值的和

使用for循环求三维数组元素值的和 的代码如下所示

	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);
  • 每个循环都遍历一个数组维。
  • 对于i的每个值,都完整地执行j控制的循环,对于i的的每个值,都完整地执行k控制的循环。

4.2、for循环求数组元素值的和的运行结果

for循环求数组元素值的和的运行结果 如下所示

在这里插入图片描述

五、使用sizeof运算符求三维数组元素值的和

5.1、sizeof运算符求数组元素值的和

使用sizeof运算符求三维数组元素值的和 的代码如下所示

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

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

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

在这里插入图片描述

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

在这里插入图片描述

6.1、问题描述

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

  • 戴太大的帽子会很危险,它会遮住眼睛,使人撞到什么东西,导致受伤甚至死亡。
  • 同样,戴太小的帽子会导致持续的头痛,让人看起来很愚蠢。本实例的程序将使用数组计算帽子的尺寸,其单位在美国和英国很常用,帽子尺寸一般是6 1/27 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. 帽子尺寸合适的运行结果
    在这里插入图片描述

  2. 帽子尺寸太大的运行结果
    在这里插入图片描述

  3. 帽子尺寸太小的运行结果
    在这里插入图片描述

七、完整程序

在这里插入图片描述

本文的完整程序如下所示

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");
	return 0;
}

八、总结

在这里插入图片描述

本文主要介绍了C语言高级编程的数组的多维数组的初始化的方式。
介绍了二维数组初始化的方式。
介绍了三(多)维数组初始化的方式。

本文到这里就结束啦。

  • 希望本文的二维(多维)数组初始化和基于数组的综合实例->帽子选购问题。
  • 对学习C语言,能对你有所帮助。
  • 你的支持是我创作的最大动力。
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/392.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

行业周期分析的主要内容,怎么分析行业生命周期

如何分析经济周期&#xff1f; 很多人认为经济周期分析很难&#xff0c;很复杂。但是作为一个投资者&#xff0c;必须了解一定的经济周期分析原理。所以今天康少就用一张图来简单讲解下经济周期的分析。 一、经济周期判断1、经济趋向繁荣&#xff1a;普通股收益将大幅提高&am…

第07篇:巧用Spring类型转换, ConverterFormatter知识点学习。

公众号: 西魏陶渊明 CSDN: https://springlearn.blog.csdn.net 天下代码一大抄, 抄来抄去有提高, 看你会抄不会抄&#xff01; 文章目录一、前言1.1 类型转换1.2 格式化输出二、Converter 类型转换2.1 Converter2.1.1 接口定义2.1.2 接口功能2.2 ConverterFactory2.2.1 接口定义…

java8特性,lambda表达式,简写的演变及应用

&#x1f36c;博主介绍 &#x1f468;‍&#x1f393; 博主主页&#xff1a;chad_chang的主页 ✨主攻领域&#xff1a;【大数据】【java】【python】【面试分析】 文章目录lambda表达式1.1.简介1.1.1.什么是Lambda&#xff1f;1.1.2.为什么使用Lambda1.1.3.Lambda对接口的要求1…

【Linux】特别篇--SMBus 协议

【Linux】特别篇--SMBus 协议一、SMBus 简介二、SMBus 与 I2C 区别三、SMBus协议分析3.1 符号含义3.2 SMBus Quick Command3.3 SMBus Receive Byte3.4 SMBus Send Byte3.5 SMBus Read Byte3.6 SMBus Read Word3.7 SMBus Write Byte3.8 SMBus Write Word3.9 SMBus Block Read3.1…

672页21万字智慧高速数据中心大数据平台建设方案

目 录 第1章 设计总述 6 1.1 项目概述 6 1.1.1 项目名称 6 1.1.2 建设单位概况 6 1.1.3 公司具备的优势 6 1.2 对项目的理解分析 7 1.2.1 项目现状分析 7 1.2.2 建设目标分析 10 1.2.3 建设内容分析 13 1.2.4 项目建设重难点分析 19 1.2.5 项目风险分析 22 1.2.6 各中心职能需求…

python控制台颜色输出设置

python控制台颜色输出设置 控制台输出内容的颜色有前景色与背景色 控制台的展示效果有限&#xff0c;并不能像前端一样炫酷&#xff0c;只能做一些简单的设置 原理 python终端的字符颜色是用转义序列控制的&#xff0c;是文本模式下的系统显示功能&#xff0c;和具体的语言无…

【C++笔试强训】第十天

&#x1f387;C笔试强训 博客主页&#xff1a;一起去看日落吗分享博主的C刷题日常&#xff0c;大家一起学习博主的能力有限&#xff0c;出现错误希望大家不吝赐教分享给大家一句我很喜欢的话&#xff1a;夜色难免微凉&#xff0c;前方必有曙光 &#x1f31e;。 &#x1f4a6; &…

操作系统的地址、数据存储和大小端问题

文章目录基本概念什么是位&#xff0c;什么是字节&#xff1f;地址总线内存地址物理地址虚拟地址寻址空间存储单元CPU位数CPU寻址大端存储和小端存储原理为什么会有大小端模式的区分基本概念 什么是位&#xff0c;什么是字节&#xff1f; 位表示的是二进制位&#xff0c;一般…

C语言中用sizeof和strlen观察数组的变化2

目录 一.前言 二.用sizeof观察字符串数组的变化 代码 运行结果 结果解释 图解 三.用sizeof观察字符数组的变化 代码 注意 运行结果 图解 注意 证明 一.前言 数组名大部分情况下是首元素的地址&#xff0c;只有两种情况除外&#xff1a; sizeof&#xff08;数组名&…

哈希桶的基本操作 || HashMap和HashSet介绍(手撕源码)

目录 前言&#xff1a; 哈希表介绍 哈希冲突 闭散列 开散列&#xff08;哈希桶&#xff09; 模拟实现哈希桶中插入和获取方法 代码实现 HashMap介绍 手撕源码 HashSet介绍 手撕源码 小结&#xff1a; 前言&#xff1a; &#x1f388;一棵搜索树的最快查找数据的时间复杂度是O(…

Java------String类和正则表达式

String在设计时被定义成了final类&#xff08;最终类&#xff09;&#xff0c;所以不能定义String类的子类&#xff0c;String用来表示字符串常量&#xff0c;是引用数据类型&#xff0c;一旦String类对象的字符序列被定义&#xff0c;那么这个字符序列的值是不能再变化的。 创…

今年十八,喜欢SQL注入

#1024程序员节&#xff5c;用代码&#xff0c;改变世界# 前言 &#x1f340;作者简介&#xff1a;被吉师散养、喜欢前端、学过后端、练过CTF、玩过DOS、不喜欢java的不知名学生。 &#x1f341;个人主页&#xff1a;被吉师散养的职业混子 &#x1fad2;每日emo&#xff1a;怀揣…

牛客竞赛每日俩题 - Day5

DP贪心 年终奖_牛客题霸_牛客网 思路&#xff1a; 定义f(i,j)表示从左上角走到坐标(i&#xff0c;j)处能获得的最大奖励。 搜索所有从左上角走到右下角的路径&#xff0c;找到最优路径。 f(i,j)分三种情况&#xff1a; 第一列&#xff1a;f(i, 0) f(i-1, 0) board(i, 0) 如果…

Java:企业应该用Java构建供应链软件吗?

很多公司使用Java编程语言&#xff0c;Java是最流行的编程语言之一&#xff0c;它帮助开发人员简化复杂企业解决方案的应用程序开发过程。 供应链是零售和制造业的重要组成部分&#xff0c;6%的零售业公司使用Java&#xff0c;另一方面&#xff0c;4%的制造公司使用编程语言&am…

基于莱维飞行扰动策略的麻雀搜索算法-附代码

基于莱维飞行扰动策略的麻雀搜索算法 文章目录基于莱维飞行扰动策略的麻雀搜索算法1.麻雀优化算法2. 改进麻雀算法2.1 莱维飞行搜索机制2.2 莱维飞行扰动策略2.3 初始化混沌搜索机制3.实验结果4.参考文献5.Matlab代码6.Python代码摘要&#xff1a;为了解决麻雀搜索算法存在迭代…

(02)Cartographer源码无死角解析-(04) 熟悉bag文件,配置.launch与.lua文件,初步调参

本人讲解关于slam一系列文章汇总链接:史上最全slam从零开始&#xff0c;针对于本栏目讲解(02)Cartographer源码无死角解析-接如下: (02)Cartographer源码无死角解析- (00)目录_最新无死角讲解&#xff1a;https://blog.csdn.net/weixin_43013761/article/details/127350885 文…

算法 | 详解斐波那契数列问题

14天阅读挑战赛 本篇是学习了《趣学算法&#xff08;第2版&#xff09;》 第一章之后总结的。 上一篇讲到了等比数列求和问题&#xff0c;求Sn122223...263&#xff1f;S_n 1 2 2^2 2^3 ... 2^{63} &#xff1f;Sn​122223...263&#xff1f;&#xff0c;该函数属于爆…

1024,我们节日

文章目录1024的前奏1024应该锻炼身体1024 &#xff1f;为何是1024其他的1024代码有Bug&#xff0c;世界却温暖特殊的一类人群&#xff08;一&#xff09;特殊的一类人群&#xff08;二&#xff09;写在最后1024的前奏 写博文的时间是23号&#xff0c;距离1024这个标志性的节日…

趣学算法14天阅读|Day2

14天阅读挑战赛 文章目录前言什么是算法&#xff1f;算法复杂度如何评定好算法案例案例一&#xff1a;棋盘的麦子案例二&#xff1a;兔子数列总结前言 &#x1f4eb; 作者简介&#xff1a;「六月暴雪飞梨花」&#xff0c;专注于研究Java&#xff0c;就职于科技型公司后端中级工…

@AutoConfigurationPackage注解详解

AutoConfigurationPackage是在springboot启动类注解SpringBootApplication下的EnableAutoConfiguration下。AutoConfigurationPackage作用是指定springboot扫描包&#xff0c;默认就是扫描启动类同包下的类。可以通过AutoConfigurationPackage来附加其他路径&#xff0c;然后sp…