当前位置: 首页 > 编程笔记 >

C语言完美实现动态数组代码分享

葛雪松
2023-03-14
本文向大家介绍C语言完美实现动态数组代码分享,包括了C语言完美实现动态数组代码分享的使用技巧和注意事项,需要的朋友参考一下

我们知道,C语言中的数组大小是固定的,定义的时候必须要给一个常量值,不能是变量。

这带来了很大的不便,如果数组过小,不能容下所有数组,如果过大,浪费资源。

请实现一个简单的动态数组,能够随时改变大小,不会溢出,也不会浪费内存空间。

下面的代码实现了简单的动态数组:

#include <stdio.h>
#include <stdlib.h>
int main()
{
  //从控制台获取初始数组大小
  int N;
  int *a;
  int i;
  printf("Input array length:");
  scanf("%d",&N);
  //分配空间
  a=(int *)calloc(N,sizeof(int));
  //填充数据
  for(i=0;i<N;i++){
    a[i]=i+1;
    printf("%-5d",a[i]);
    if((i+1)%10==0){
      printf("\n");
    }
  }
  //释放内存
  free(a);
  a=NULL;
  printf("\n");
  return 0;
}

运行结果:

Input array length:20
1  2  3  4  5  6  7  8  9  10
11  12  13  14  15  16  17  18  19  20
 类似资料:
  • 本文向大家介绍C语言构建动态数组完整实例,包括了C语言构建动态数组完整实例的使用技巧和注意事项,需要的朋友参考一下 本文以一个完整的实例代码简述了C语言构建动态数组的方法,供大家参考,完整实例如下: 运行结果如下:

  • 本文向大家介绍Java语言求解完美数代码分析,包括了Java语言求解完美数代码分析的使用技巧和注意事项,需要的朋友参考一下 1、概念 首先我们理解一下,什么叫做完美数? 问题描述:若一个自然数,它所有的真因子(即除了自身以外的约数)的和恰好等于它本身,这种数叫做完全数。简称“完数” 例如,   6=1+2+3   28=1+2+4+7+14   496=1+2+4+8+16+31+62+124+2

  • 本文向大家介绍C语言实现树的动态查找实例代码,包括了C语言实现树的动态查找实例代码的使用技巧和注意事项,需要的朋友参考一下 C语言实现树的动态查找实例代码 本例演示一种树数据结构存储记录集合时的动态查找方法。首先程序通过construct()函数,利用已经存在的结构体数组数据建立一个二叉树,建立树的过程中,要保证每个节点的值都大于它的左子树上节点的值而小于它右子树所有节点的值,该函数返回建立树的根

  • 本文向大家介绍C语言实现的bitmap位图代码分享,包括了C语言实现的bitmap位图代码分享的使用技巧和注意事项,需要的朋友参考一下 事实上,我们是用每一个 元素表示一个32位的二进制字符串,这样这个元素可以保留相邻32个号码是否存在的信息,数组范围就下降到10000000/32了.例如对于号码 89256,由于89256 mod 32=2789…8,这样我们应该置a[2789]中32位字符串的

  • 本文向大家介绍C语言代码实现2048游戏,包括了C语言代码实现2048游戏的使用技巧和注意事项,需要的朋友参考一下 我是大一新生,在寒假的实训课上老师让我们用c语言分组编程一个小游戏,我们组选的是“2048”。由于我们组上有一个大神,于是我们把大部分的工作交给了大神做,但是实训完成之后我感觉到碌碌无为,什么也没学到,自己对于c语言的理解也仅仅局限于书本之上,想到那些大神们已经基本可以自己编程一些小

  • 本文向大家介绍C语言实现的统计素数并求和代码分享,包括了C语言实现的统计素数并求和代码分享的使用技巧和注意事项,需要的朋友参考一下 题目来源于PAT平台,此题又是费了一番脑子。题目要求输出给定区间内的素数个数并对他们求和。具体思路是利用循环判断素数,将结果传递给控制变量,由控制变量再来判断是否执行自增以及求和。当然这里必须要注意1既不是素数也不是合数。 下面是代码: