分享c语言初始化数组简单还实用的四种方法

目录

前言

一.memset——更少的代码量实现初始化全为0

 函数原型

 参数

字符数组

 整型数组

二.数组元素随机生成

1.整型数组

1.1一维数组

2.2二维数组

2.字符数组

三.数组元素的自定义输入

1.整型数组

1.1一维数组

1.2二维数组

四,动态内存malloc函数

malloc实现一维动态数组p[m]

malloc实现二维动态数组p[m][n]:


前言

初识c语言中,不满于每次屏幕打印都是固定值,因为这段代码只能解决那一个问题。我们肯定希望哪怕在release版本中能解决更多相似的问题,这就需要数组的长度在写完代码但运行前都是未定的,并且有些情况需要我们自己指定元素是什么,有些是需要电脑随机生成。

一.memset——更少的代码量实现初始化全为0

 函数原型

memset函数包含c标头的头文件(注意不是c++的头文件)

#include<string.h>     //  头文件 
void *memset(void *s, int c, unsigned long n);   //  函数声明

 参数

s指向要填充的内存块,也就是我们的变量名。

c是要被设置的值。    // 虽然是int类型的,但在c99标准中‘a'其实就是整型字符常量,值为97

n是要被设置该值的字符数。//也就是字节数,用sizeof来求

返回类型是一个指向存储区s的指针。

字符数组

由于memset函数是按照字节对内存块进行初始化,而char类型的大小正好是1个字节,因此对字符数组统一赋值特别方便。

#include<stdio.h>
#include<string.h>
int main()
{
	char arr[5] = { 0 };
	memset(arr, 97, sizeof(arr) - 1);
	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]) - 1 ; i++)
	{
		printf("%c ", arr[i]);
	}
	printf("\n%s\n", arr);
	return 0;
}

 输出结果:

整型数组

只能赋值0和-1,不能任意赋值,但这也够了,我们也原本只是想刚初始化时赋值为0

下面解释原因:

还是因为memset函数是按照字节对内存块进行初始化,1个字节的范围是在0~255,所以c的实际范围应该在0~255。因为memset函数只能取c的后八位给所输入范围的每个字节。也就是说无论c多大只有后八位二进制是有效的。所以更准确来说,只能赋值成高字节和低字节相同的。如果赋值为1

#include<stdio.h>
#include<string.h>
int main()
{
	int arr[5] = { 0 };
	memset(arr, 1, sizeof(arr) - 1);
	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]) - 1; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

输出结果: 

二.数组元素随机生成

1.整型数组

1.1一维数组

我们如果要大小随机,元素随机的数组,只需要借助rand函数就行了。注意用srand函数初始随机化种子。使用rand函数要包含<stdlib.h>头文件,而srand需要<time,h>头文件

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main()
{
	srand((unsigned int)time(NULL));
	int n = rand() % 49 + 1;
	int arr[51] = { 0 };
	for (int i = 0; i < n; i++)
	{
		arr[i] = rand() % 99 + 1;
		printf("%d ", arr[i]);
	}
	return 0;
}
 

 

这样就完成了对一维数组的随机赋值

2.2二维数组

与一维数组同样的原理,不管是元素具体的值,还是数组本身的大小,都是可以随机自动生成的。

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main()
{
	srand((unsigned int)time(NULL));
	int row = rand() % 9 + 1;
	int col = rand() % 9 + 1;
	int arr[12][12];
	for (int i = 0; i < row; i++)
	{
		col = rand() % 9 + 1;
		for (int j = 0; j < col; j++)
		{
			arr[i][j] = rand() % 99 + 1;
			printf("%2d ", arr[i][j]);
		}
		printf("\n");
	}
	return 0;
}

 

2.字符数组

与整型数组原理一致,只不过rand的范围要在32~126之间,因为根据ASCII值,这范围内的数据才是可以打印的。

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main()
{
	srand((unsigned int)time(NULL));
	int n = rand () % 48 + 1;
	char arr[50] = { 0 };
	for (int i = 0; i < n - 1; i++)
	{
		arr[i] = rand() % 95 + 32;
	}
	printf("%s", arr);
	return 0;
}

 

二维数组就不再赘述

三.数组元素的自定义输入

1.整型数组

1.1一维数组

他的自定义输入就得利用到循环输入,由于长度不确定,用count来输一个表示加一个,同时回车表示结束。

#include<stdio.h>
int main()
{
	int arr[100] = { 0 };
	int count = 0;
	do
	{
		scanf("%d", &arr[count]);
		count++;
	} while (getchar() != '\n');
    for(int i = 0;i < count; i++)
    {
        printf("%d ",arr[i]);
    }

	return 0;
}

//
输入:-1 2 8 9
输出:-1 2 8 9

1.2二维数组

就像定义一个数组一样,一维数组可以不管,但二维数组必须指定有多少列。

#include<stdio.h>
int main()
{
	int arr[50][50] = {0};
	int row = 0;
	int col = 0;
	printf("请输入每列有几个元素:>>");
	scanf("%d", &col);
	getchar();
        do
	{
		for (int i = 0; i < col; i++)
		{
			scanf("%d", &arr[row][i]);
		}
		row++;
	} while (getchar() != '\n');
	for (int i = 0; i < row; i++)
	{
		for (int j = 0; j < col; j++)
		{
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}

	return 0;
}

四,动态内存malloc函数

malloc实现一维动态数组p[m]

#include<stdio.h>
#include<stdlib.h>
#include<memory.h>
int main(void)
{
    int m;
    scanf("%d", &m);
    int* const p = (int*)malloc(m*(sizeof(int)));
    memset(p, 0, m);//初始化,每个元素都为零
    int i;
 //赋值
     for (i=0;i<m; i++)
    {
        p[i] = i;
    }
//打印数组
    for (i = 0; i <m; i++)
    {
        printf("%d,", p[i]);
    }
    return 0;
}

malloc实现二维动态数组p[m][n]

#include <stdio.h>
#include <stdlib.h>
#include <memory.h>
int main()
{
    int m, n;
    scanf("%d %d", &m,&n);
    int **p;
    p = (int**)malloc(m*(sizeof(int*)));//二级指针所在地址申请内存
    int i, j;
    for (i = 0; i<m; i++)
        p[i] = (int*)malloc(sizeof(int)*n);//一级指针所在地址申请内存
    for (i = 0; i < m; i++)
        for (j = 0; j < n; j++)
            p[i][j] = i + j;
    for (i = 0; i < m; i++)
    {
        for (j = 0; j < n; j++)
        {
            printf("%d %p   ", p[i][j], &p[i][j]);     //输出每个元素及地址,每行的列与列之间的地址时连续的,行与行之间的地址不连续  
        }
        printf("\n");
    }  
    return 0;
}

好了,今天的分享就到这里了,由于身体原因,状态不是很好,如有什么不足和错误,还望大佬能多多指正

  • 45
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 31
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 31
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值