c++三维静态数组的定义与作为函数的传递

时间:2022-10-26 00:09:57

  在c++中,我们可以定义三维数组,并且可以将之作为参数直接传递。

  定义:

#include <iostream>
#include <windows.h>
using namespace std;
const int x = ;
const int y = ;
const int z = ;
int main() {
double foo[x][y][z];
for (int i = ; i < x; i++) {
for (int j = ; j < y; j++) {
for (int k = ; k < z; k++) {
foo[i][j][k] = 1.0;
}
}
}
cout << foo[][][] << endl; // 1.0
system("pause");
return ;
}

  如上所示,我们设置的是静态数组,所以必须在定义三维数组之前确定其大小,为了程序的可维护性,建议使用const int进行定义。

  将三维数组作为参数传递:

#include <iostream>
#include <windows.h>
using namespace std;
const int x = ;
const int y = ;
const int z = ;
int bar(double arr[][y][z]);
int main() {
double foo[x][y][z];
for (int i = ; i < x; i++) {
for (int j = ; j < y; j++) {
for (int k = ; k < z; k++) {
foo[i][j][k] = 1.0;
}
}
}
cout << foo[][][] << endl; // 1.0
bar(foo);
system("pause");
return ;
}
int bar(double arr[][y][z]) {
cout << "function invoked value: " << arr[][][] << endl;
return ;
}

  如上所示,最终结果为:

function invoked value1

  注意,在传递三维数组作为参数时,数组的第一个[]中为空,而第二第三个不能为空。

  这样,对于大部分情况下的三维数组就可以轻松处理了。

c++三维静态数组的定义与作为函数的传递的更多相关文章

  1. c&num;中数组array和list在函数间传递 转置

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  2. JS 索引数组、关联数组和静态数组、动态数组

    JS 索引数组.关联数组和静态数组.动态数组 数组分类: 1.从数组的下标分为索引数组.关联数组 var ary1 = [1,3,5,8]; //按索引去取数组元素,从0开始(当然某些语言实现从1开始 ...

  3. C语言指针与数组的定义与声明易错分析

    部分摘自<C语言深度解剖> 1.定义为数组,声明为指针 在文件1中定义: char a[100]; 在文件2中声明: extern char *a; //这样是错误的 这里的extern告 ...

  4. JAVA数组的定义及用法

    数组是有序数据的集合,数组中的每一个元素具有同样的数组名和下标来唯一地确定数组中的元素. 1. 一维数组 1.1 一维数组的定义 type arrayName[]; type[] arrayName; ...

  5. C和Java中数组的定义

    在学习C和Java中,关于数组的定义两者不同,在初学的时候,容易产生混淆,现在将两者对比下. 1.初始化 在C语言中,关于一维数组的定义: 完全初始化  int a[5]={1,2,3,4,5},对于 ...

  6. C&sol;C&plus;&plus;静态数组与动态数组的区别

    简介 以下三行代码有什么区别? int a[10]; int *a = (int*)malloc(sizeof(int)*10); int *a = new int[10]; 第一行代码定义a为包含1 ...

  7. &quot&semi;《算法导论》之&OpenCurlyQuote;队列’&quot&semi;:队列的三种实现(静态数组、动态数组及指针)

    本文有关栈的介绍部分参考自网站数据结构. 1. 队列  1.1 队列的定义 队列(Queue)是只允许在一端进行插入,而在另一端进行删除的运算受限的线性表. (1)允许删除的一端称为队头(Front) ...

  8. &quot&semi;《算法导论》之&OpenCurlyQuote;栈’&quot&semi;:栈的三种实现(静态数组、动态数组及指针)

    本文有关栈的介绍部分参考自网站数据结构. 1. 栈  1.1 栈的定义 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表. (1)通常称插入.删除的这一端为栈顶(Top),另一端称为栈底( ...

  9. java 数组声明定义 数组内存分配 数组初始化 数组引用 数组的遍历

    一,数组的定义 Java 中定义数组的语法有两种: 1. type arrayName[]; 2. type[] arrayName;type 为Java中的任意数据类型,包括基本类型和组合类型,ar ...

随机推荐

  1. &lpar;转&rpar;CString截取字符串全攻略

    附:去掉空格方法 CString str("e w r we  中华ADF 华AG中"); newstr=str.Replace(" ", "&quo ...

  2. C&num; 依赖注入

      http://www.cnblogs.com/leoo2sk/archive/2009/06/17/1504693.html 这篇文章真的非常非常好···绝对值得收藏学习.     目录 目录 1 ...

  3. linux终端使用技巧

    Shift+Ctrl+T:新建标签页Shift+Ctrl+W:关闭标签页Ctrl+PageUp:前一标签页Ctrl+PageDown:后一标签页Shift+Ctrl+PageUp:标签页左移Shift ...

  4. JavaEE基础(十九)&sol;异常和File

    1.异常(异常的概述和分类) A:异常的概述 异常就是Java程序在运行过程中出现的错误. B:异常的分类 通过API查看Throwable Error 服务器宕机,数据库崩溃等 Exception ...

  5. org&period;springframework&period;dao&period;EmptyResultDataAccessException

    public Wcrash getWcrashInfo(int id) { String sql = "select plateform_id,android_version,app_ver ...

  6. hdu 2489 Minimal Ratio Tree

    http://acm.hdu.edu.cn/showproblem.php?pid=2489 这道题就是n个点中选择m个点形成一个生成树使得生成树的ratio最小.暴力枚举+最小生成树. #inclu ...

  7. Python、PyCharm的安装及使用方法(Mac版)

    上周跟朋友喝咖啡时聊起我想学Python,她恰好也有这个打算,顺便推荐了一本书<编程小白的第1本Python入门书>,我推送到Kindle后,随手翻看了下,用语平实,简洁易懂. 之前在R语 ...

  8. 使用BeautifulSoup

    下载bs4,导入BeautifulSoup pip install bs4 from bs4 import BeautifulSoup BeautifulSoup 的使用 创建对象 r = reque ...

  9. 51Nod1309 Value of all Permutations 期望

    原文链接https://www.cnblogs.com/zhouzhendong/p/51Nod1309.html 题目传送门 - 51Nod1309 题意 长度为N的整数数组A,有Q个查询,每个查询 ...

  10. R语言 启动报错 &ast;&ast;&ast; glibc detected &ast;&ast;&ast; &sol;usr&sol;lib64&sol;R&sol;bin&sol;exec&sol;R&colon; free&lpar;&rpar;&colon; invalid next size &lpar;fast&rpar;&colon; 0x000000000263a420 &ast;&ast;&ast; 错误 解决方案

    *** glibc detected *** /usr/lib64/R/bin/exec/R: free(): invalid next size (fast): 0x000000000263a420 ...