数组浅谈:

        数组是计算机语言很重要的一个组成部分,很多算法都需要用到数组。数组里又有一维数组,二维数组,三维,多维之分。也有普通的数组和字符数组,指针数组,布尔数组等的不同分类。

        数组简单来说就是存储一堆数的一个容器。数组定义大概的样子就是这样:

int a[Number];

[ ]里的就是数组的下标,用于读取数组中第Number个元素的值。这里要注意一下,数组的下标是从0开始的,也就是说a[0]是这一堆数中第一个数,a[1]是第二个,以此类推。当然我们也可以从数组的第1号下标开始赋值,这样的话,以后对数组进行处理的时候就需要注意。

        数组的使用一般包括三步:1.数组定义初始化   2.数组具体处理   3.数组遍历输出。

我们用一个简单的例题看一看这三步(c语言为例):输入n个数,然后将这n个数按原顺序的逆序输出。0<n<50

INPUT:先输入n,再输入n个数。   OUTPUT:这n个数原顺序的逆序。

eg:输入5    

3 1 2 4 5

输出:5 4 2 1 3

#include <stdio.h>

int main(){
	//定义变量区 
	int n;
	int i;
	int a[100];
	//得到数n 
	scanf("%d",&n);
	//数组初始化区 
	for(i=0;i<n;i++){
		scanf("%d",&a[i]);
	}
	//数组遍历输出 
	for(i=n-1;i>=0;i--){
		printf("%d ",a[i]);
	}
	return 0;
}

这个题我们不需要对这个数组进行中间具体处理,以后复杂的题可能会遇到,根据具体情况进行处理。下面我们来具体解释一下这个题。为了防止数组越界,我们数组的定义一般来说会比实际用到的大一点。对于初始化,我们用for循环对数组中n个元素进行逐一赋值,for循环扫一遍数组中n个数成为数组遍历。这个题我们从0开始赋值,再从数组结束的地方,也就是n-1的位置往前到0再来遍历输出一遍这个题就能解决。

         接下来看一个稍微复杂点的题:

 这个题我们可以先用一个while循环统计一下数字位数,然后分割,得到每一位数字,然后存在数组中,最后遍历数组输出数字每一位即可。

#include <stdio.h>

int main(){
	int a[20];
	int i,n;
	int t;
	int count=0;
	scanf("%d",&n);
	t=n;
	while(t>0){
		t/=10;
		count++;
	}
	for(i=0;i<count;i++){
		a[i]=n%10;
		n/=10;
	}
	for(i=count-1;i>=0;i--){
		printf("%d ",a[i]);
	}
	return 0;
}

数组在以后的算法中的运用相当普遍,对于数组从0开始适应需要一定的时间,多做一点题,练一练熟练度就可以了。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值