不管几维,对内存而言都是线性的结构,而人们总是习惯把抽象和现实联系起来。4维理解成n个3维组成的就好了。总之,不管多少维,都是线性的。
你无须按照空间理念去理解数组,C语言里还有N维数组呢,无非就是a[][][][][]...而已,可以存进更多的数据。
举个例子吧,一维数组a[9]可以存10个元素
二维a[9][9]可以存100个元素,
三维a[9][9][9]可以存1000个元素
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
#include<stdio.h>
int main()
{ int i,a[4]={101,102,103,104}
for(i=0i<4i++)
printf("%p:%d\n",a+i,a[i])
return 0
}
#include <stdio.h>void main()
{
int a[4][4], i, j, sum = 0, max, max_x = 0, max_y = 0
long pro = 1
printf("enter: ")
for(i = 0i <4i++)
for(j = 0j <4j++)
scanf("%d", &a[i][j]) //输入
max = a[0][0] //初始化max
for(i = 0i <4i++)
for(j = 0j <4j++)
if(i == j || i + j == 3) { //判断是否在对角线上
sum = sum + a[i][j] //计算和
if(i%2 == 0 &&j%2 == 0) //判断下标是否都为偶数
pro = pro * a[i][j] //计算积
if(a[i][j] >max) { //找最大数
max = a[i][j]
max_x = i
max_y = j
} //如果最大数不止一个,将输出坐标最大的那个的坐标
printf("\nsum = %d\nproduct = %ld\nmaxnumber = %d, located in (%d, %d).", sum, pro, max, max_x, max_y)
}