- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 C 编程新手,我需要任何熟悉 3D 数组并可以通过函数对其进行一些更改的人的帮助。 我在网上找到的所有解释都基于二维数组。我无法理解他们。
我的意思是,我了解指针、函数原型(prototype)(声明)、函数定义以及如何操作一维数据数组的基础知识。
我知道任何函数调用都可以进行本地复制或更改其物理存储中的变量数据,但我无法理解一件事。当您使用 char *
类型参数(数组)调用函数时,您总是输入类似 — void func_name(char * var_name)
— 因此,如果您需要更改值,您就这样输入它,当您不需要更改时,您可以在 char * var_name
之前添加 const
。 对于 int
和 char
类型的参数,我们还有另一个规则:您必须在 func 原型(prototype)中添加(de?)引用运算符 - *
及其定义,如果要更改存储中的变量数据,不需要更改则不必使用它(“获取本地副本”命令);并且,如果您必须更改变量数据,则必须使用应用于参数的取消引用运算符 &
来调用 func — 例如 void func_name(&var_name);
。
当我的任务是通过特定函数(“填充第一维”、“填充第三维”、“读取第 N 维(本地副本)”命令)操作 3D 数组时,您能否解释一下如何正确操作?我如何编写函数原型(prototype)来更改而不是更改 3D 数组的值?
void func_name(char *array[][][])
— 这是正确的吗?
void func_name( char *(***array) )
— 或者也许像这样?
如果我必须使用每个维度中的元素进行操作,我是否必须创建这样的函数原型(prototype)? :
void func_name( char *(*array), char *(**array), char *(***array) ) {. . .}
调用3D数组操作函数有什么具体规则吗?或者我只需要像 func_name(var_name);
一样保留它们?
我找到了一些工作代码,它们试图解释如何定义一个以二维数组作为参数的函数,以及如何调用这个仅“读取”二维数组(获取本地副本)的函数。但这段代码并没有让我清楚如何使用函数执行另一个操作(“填充”)以及如何正确编写原型(prototype)。而且,该示例仅具有 int
类型的操作,但我需要 char *
..代码:
#include <stdio.h>
const int M = 3;
const int N = 3;
void print(int arr[M][N])
{
int i, j;
for (i = 0; i < M; i++)
for (j = 0; j < N; j++)
printf("%d ", arr[i][j]);
}
int main()
{
int arr[][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
print(arr);
char answer[10];
printf("ok? : ");
scanf("%s", answer);
return 0;
}
最后,我无法清楚地理解这些短语的含义:“指向字符的指针的二维数组”,“指向字符的二维数组的指针”;我无法理解上下文,在哪里使用“指针数组”以及在哪里使用“指向数组的指针”。我头脑中的困惑源于这样一个事实:在函数原型(prototype)和定义中,我们使用 (type-name) *
作为类型,始终将数组作为函数参数。
问题比较多,希望大家帮忙,谢谢!
编辑1:
伙计们,我已经研究了一段时间并得到了一些工作编译,这解决了我的任务。感谢大家的反馈,我的解决方案如下。
解决方案:
#include <stdio.h>
void find(int a, char *name, char *country, char *city, const char (*paaa)[4][100]);
void fill( char (*paaa)[4][100] );
// --------------------------------------------//
int main()
{
char name[100] = {0}, country[50] = {0}, city[50] = {0};
char array3D[100][4][100]; // 0 field is for name, 1 - for city, 2 - for country
char (*paaa)[4][100] = &array3D[0]; // initialize the pointer 'paaa'
fill(paaa); // fills 12 entries with the same data in each field
printf("> full array: \n");
printf("\033[0;34m"); // set text color to blue
for (int x = 0; x < 12*4; x++) // each entry contains 4 fields of strings, so '12*4' here
{
printf("%s", (*paaa)[x]);
}
printf("\033[0m"); // reset text color to default
int a = 0;
printf("> input entry number(max:11): ");
scanf("%u", &a);
printf("\n");
find(a, name, country, city, paaa); // retrieve each field in variables
printf("ENTRY No. %u : \n\n", a);
printf("> Name - %s\n", name);
printf("> City - %s\n", city);
printf("> Country - %s\n", country);
printf("> Good? : ");
scanf("%u", &a);
printf("> Done.\n\n");
return 0;
}
// --------------------------------------------//
void fill( char (*paaa)[4][100] )
{
char local_name[50] = { " Jacob Goodman \n" };
char local_city[50] = { " Melbourne \n" };
char local_country[50] = { " Australia \n" };
int entries_amount = 12;
int en = 0, da = 0; //entry, data
for (en = 0; en < entries_amount ; en++)
{
for ( da = 0; local_name[da] != '\0'; da++)
{
paaa[en][0][da] = local_name[da];
}
for ( da = 0; local_city[da] != '\0'; da++)
{
paaa[en][1][da] = local_city[da];
}
for ( da = 0; local_country[da] != '\0'; da++)
{
paaa[en][2][da] = local_country[da];
}
}
}
// takes an entry number,
// reads from 3D-array 3 fields of given entry
// and saves each field to 3 global variables
void find(int a, char *name, char *city, char *country, const char (*paaa)[4][100])
{
int da = 0;
for ( da = 0; paaa[a][0][da] != '\0'; da++)
{
name[da] = paaa[a][0][da];
}
for ( da = 0; paaa[a][1][da] != '\0'; da++)
{
city[da] = paaa[a][1][da];
}
for ( da = 0; paaa[a][2][da] != '\0'; da++)
{
country[da] = paaa[a][2][da];
}
}
最佳答案
“指向 T 的指针”可用于指向单个 T 变量或指向 T 数组的第一个元素。T 数组的所有元素都可以通过指针访问。
T a;
T arr[3]; // Array [3] of T
T *pa = &a; // Pointer to T
T *parr = &arr[0]; // Pointer to T. Equivalent initializer: T *parr = arr;
*pa = foo; // will set a = foo;
parr[2] = bar; // will set arr[2] = bar;
pa
和 parr
都是“指向 T 的指针”类型。
“T 的二维数组”是“T 的数组的数组”:
T aa[4][3]; // Array [4] of array [3] of T
aa[0][1] = foo;
“指向 T 的指针数组”可用于模拟 T 的二维数组。每个指针元素都指向其自己的 T 数组,该数组可以动态分配,如下所示:
T *ad[4]; // Array [4] of pointer to T
for (i = 0; i < 4; i++) {
ad[i] = calloc(3, sizeof (T));
}
ad[0][1] = foo;
“指向 T 数组的指针”可用于访问 T 的二维数组的元素:
T aa[4][3]; // Array [4] of array [3] of T
T (*paa)[3] = aa; // Pointer to array [3] of T. Equivalent initializer: T (*paa)[3] = &aa[0];
paa[0][1] = foo; // will set aa[0][1] = foo;
“指向 T 的指针的指针”可用于访问“指向 T 的指针的数组”的元素:
T arow0[3], arow1[3], arow2[3], arow3[3]; // Each is array [3] of T
T *ad[4] = {arow0, arow1, arow2, arow3}; // Array [4] of pointer to T
T **pad = &ad[0]; // Pointer to pointer to T. Equivalent initializer: T **pad = ad;
pad[0][1] = foo; // will set ad[0][1] = foo; will set arow0[1] = foo;
“T 的 3 维数组”是“T 的数组的数组的数组”:
T aaa[4][3][2]; // Array [4] of array [3] of array [2] of T
“指向 T 的 2 维数组的指针”是“指向 T 的数组的数组的指针”,可用于访问 T 的 3 维数组(具有兼容维度)的元素:
T aaa[4][3][2]; // Array [4] of array [3] of array [2] of T
T (*paaa)[3][2]; // Pointer to array [3] of array [2] of T
paaa = aaa; // Equivalent: paaa = &aaa[0];
paaa[0][1][1] = foo; // will set aaa[0][1][[1] = foo;
“指向 T 的指针的二维数组”是“指向 T 的指针数组的数组”:
T arow00[2], arow01[2], arow02[2]; // Each is array [2] of T
T arow10[2], arow11[2], arow12[2];
T arow20[2], arow21[2], arow22[2];
T arow30[2], arow31[2], arow32[2];
T *app[4][3] = {
{arow00, arow01, arow02},
{arow10, arow11, arow12},
{arow20, arow21, arow22},
{arow30, arow31, arow32}
}; // Array [4] of array [3] of pointer to T
app[0][1][1] = foo; // Will set arow01[1] = foo;
“指向指向 T 的指针的指针”可用于访问指向 T 的指针的指针数组的元素:
T arow00[2], arow01[2], arow02[2]; // Each is array [2] of T
T arow10[2], arow11[2], arow12[2];
T arow20[2], arow21[2], arow22[2];
T arow30[2], arow31[2], arow32[2];
T *parow0[3] = { arow00, arow01, arow02 }; // Each is array [3] of pointer to T
T *parow1[3] = { arow10, arow11, arow12 };
T *parow2[3] = { arow20, arow21, arow22 };
T *parow3[3] = { arow30, arow31, arow32 };
T **ppa[4] = { parow0, parow1, parow2, parow3 }; // Array [4] of pointer to pointer to T
T ***pppa = ppa; // Pointer to pointer to pointer to T;
pppa[0][1][1] = foo;
// will set ppa[0][1][1] = foo;
// will set parow0[1][1] = foo;
// will set arow01[1] = foo;
关于c - 如何在 C 程序中声明、定义和调用函数,该函数必须具有 1 )"fill"3D 数组和 2 )"read"3D 字符数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59396886/
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我试图用这种形式简单地获取数字 28 integer+space+integer+integer+space+integer我试过这个正则表达式 \\s\\d\\d\\s 但我得到了两个数字11 和
最近一直在学习D语言。我一直对运行时感到困惑。 从我能收集到的关于它的信息中,(这不是很多)我知道它是一种有助于 D 的一些特性的运行时。像垃圾收集一样,它与您自己的程序一起运行。但是既然 D 是编译
想问一下这两个正则表达式有区别吗? \d\d\d 与 \d{3} 我已经在我的本地机器上使用 Java 和 Windows 操作系统对此进行了测试,两者都工作正常并且结果相同。但是,当在 linux
我正在学习 Go,而且我坚持使用 Go 之旅(exercise-stringer.go:https://tour.golang.org/methods/7)。 这是一些代码: type IPAddr
我在Java正则表达式中发现了一段令我困惑的代码: Pattern.compile( "J.*\\d[0-35-9]-\\d\\d-\\d\\d" ); 要编译的字符串是: String string
我在 ruby 代码上偶然发现了这个。我知道\d{4})\/(\d\d)\/(\d\d)\/(.*)/是什么意思,但是\1-\2-\3-\4 是什么意思? 最佳答案 \1-\2-\3-\4 是 b
我一直在努力解决这个问题,这让我很恼火。我了解 D 运行时库。它是什么,它做什么。我也明白你可以在没有它的情况下编译 D 应用程序。就像 XoMB 所做的那样。好吧,XoMB 定义了自己的运行时,但是
我有两个列表列表,子列表代表路径。我想找到所有路径。 List> pathList1 List> pathList2 当然是天真的解决方案: List> result = new ArrayList>
我需要使用 Regex 格式化一个字符串,该字符串包含数字、字母 a-z 和 A-Z,同时还包含破折号和空格。 从用户输入我有02-219 8 53 24 输出应该是022 198 53 24 我正在
目标是达到与this C++ example相同的效果: 避免创建临时文件。我曾尝试将 C++ 示例翻译为 D,但没有成功。我也尝试过不同的方法。 import std.datetime : benc
tl;dr:你好吗perfect forwarding在 D? 该链接有一个很好的解释,但例如,假设我有这个方法: void foo(T)(in int a, out int b, ref int c
有什么方法可以在 D 中使用abstract auto 函数吗? 如果我声明一个类如下: class MyClass { abstract auto foo(); } 我收到以下错误: mai
有没有人为内存中重叠的数组切片实现交集?算法在没有重叠时返回 []。 当 pretty-print (使用重叠缩进)内存中重叠的数组切片时,我想要这个。 最佳答案 如果您确定它们是数组,那么只需取 p
我已经开始学习 D,但我在使用 Andrei Alexandrescu 所著的 The D Programming Language 一书中提供的示例时遇到了一些麻烦。由于 int 和 ulong 类
如何创建一个不可变的类? 我的目标是创建一个实例始终不可变的类。现在我只是用不可变的方法和构造函数创建了一个“可变”类。我将其称为 mData,m 表示可变。然后我创建一个别名 alias immut
不久前我买了《The D Programming Language》。好书,很有教育意义。但是,我在尝试编译书中列出的语言功能时遇到了麻烦:扩展函数。 在这本书中,Andrei 写了任何可以像这样调用
我在 D http://www.digitalmars.com/d/2.0/lazy-evaluation.html 中找到了函数参数的惰性求值示例 我想知道如何在 D 中实现可能的无限数据结构,就像
这个问题在这里已经有了答案: 12 年前关闭。 Possible Duplicate: Could anyone explain these undefined behaviors (i = i++
当前是否可以跨模块扫描/查询/迭代具有某些属性的所有函数(或类)? 例如: source/packageA/something.d: @sillyWalk(10) void doSomething()
我是一名优秀的程序员,十分优秀!