全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

数据结构之数组Array实例详解

数据结构之数组Array实例详解

数组Array

基本操作

Status InitArray(int dimm,...)//若维数dim和随后的各维长度合法,则构造相应的数组A,并返回OK 
Status DestroyArray()  //销毁数组A 
Status Locate(va_list ap,int &off) //若ap指示的各下标值合法,则求出该元素在A中相对地址off 
Status Value(ElemType &e,...)  //A是n维数组,e为元素变量,随后是n个下标值。若各下表不越界,则e赋值为所指定的A的元素值,并返回OK。 
Status Assign(ElemType e,...)  //A是n维数组,e为元素变量,随后是n各下表值。/若各下标不越界,则将e的值付给所指定的A的元素,并返回OK。 

几个小程序(代码正误检验)

// 
//by coolxxx 
//#include<bits/stdc++.h> 
#include<iostream> 
#include<algorithm> 
#include<string> 
#include<iomanip> 
#include<map> 
#include<stack> 
#include<queue> 
#include<set> 
#include<bitset> 
#include<memory.h> 
#include<time.h> 
#include<stdio.h> 
#include<stdlib.h> 
#include<string.h> 
//#include<stdbool.h> 
#include<math.h> 
#define min(a,b) ((a)<(b)?(a):(b)) 
#define max(a,b) ((a)>(b)?(a):(b)) 
#define abs(a) ((a)>0?(a):(-(a))) 
#define lowbit(a) (a&(-a)) 
#define sqr(a) ((a)*(a)) 
#define swap(a,b) ((a)^=(b),(b)^=(a),(a)^=(b)) 
#define mem(a,b) memset(a,b,sizeof(a)) 
#define eps (1e-10) 
#define J 10000 
#define mod 1000000007 
#define MAX 0x7f7f7f7f 
#define PI 3.14159265358979323 
#pragma comment(linker,"/STACK:1024000000,1024000000") 
#define N 8 
const int OK=1; 
const int ERROR=0; 
const int INFEASIBLE=-1; 
typedef int Status; 
using namespace std; 
typedef long long LL; 
double anss; 
LL aans; 
int cas,cass; 
LL n,m,lll,ans; 
 
typedef int ElemType; 
#include<stdarg.h>      //标准头文件,提供宏va_start、va_arg、va_end 用于存取变长参数表 
const int MAX_ARRAY_DIM=8; //假设数组维数的最大值为8 
typedef struct 
{ 
  ElemType *base;     //数组元素基址,由InitArray分配 
  int dim;        //数组维数 
  int *bounds;      //数组维界基址,由InitArray分配 
  int *constants;     //数组映像函数常量基址,由InitArray分配 
  int elemtotal; 
  Status InitArray(int dimm,...)//若维数dim和随后的各维长度合法,则构造相应的数组A,并返回OK 
  { 
    int i; 
    va_list ap; 
    if(dimm<1 || dimm>MAX_ARRAY_DIM)return ERROR; 
    dim=dimm; 
    bounds=(int *)malloc(dim*sizeof(int)); 
    if(!bounds)exit(OVERFLOW);//若各维长度合法,则存入A.bounds,并求出A的元素总数elemtotal 
    elemtotal=1; 
    va_start(ap,dim);  //ap为va_list类型,是存放变长参量数表信息的数组 
    for(i=0;i<dim;i++) 
    { 
      bounds[i]=va_arg(ap,int); 
      if(bounds[i]<0)return UNDERFLOW; 
      elemtotal*=bounds[i]; 
    } 
    va_end(ap); 
    base=(ElemType *)malloc(elemtotal*sizeof(ElemType)); 
    if(!base)exit(OVERFLOW); 
    constants=(int *)malloc(dim*sizeof(int)); 
    //求映像函数的常数ci,并存入A.constants[i-1],i=1,...,dim 
    if(!constants)exit(OVERFLOW); 
    constants[dim-1]=1; //L=1,指针的增减以元素的大小为单位 
    for(i=dim-2;i>=0;i--) 
      constants[i]=bounds[i+1]*constants[i+1]; 
    return OK; 
  }//InitArray 
   
  Status DestroyArray()  //销毁数组A 
  { 
    if(!base)return ERROR; 
    free(base);base=NULL; 
    if(!bounds)return ERROR; 
    free(bounds);bounds=NULL; 
    if(!constants)return ERROR; 
    free(constants);constants=NULL; 
    return OK; 
  }//DestroyArray 
   
  Status Locate(va_list ap,int &off) //若ap指示的各下标值合法,则求出该元素在A中相对地址off 
  { 
    int i,ind; 
    off=0; 
    for(i=0;i<dim;i++) 
    { 
      ind=va_arg(ap,int); 
      if(ind<0 || ind>=bounds[i])return OVERFLOW; 
      off+=constants[i]*ind; 
    } 
    return OK; 
  }//Locate 
   
  Status Value(ElemType &e,...)  //A是n维数组,e为元素变量,随后是n个下标值。 
                  //若各下表不越界,则e赋值为所指定的A的元素值,并返回OK。 
  { 
    va_list ap; 
    int result,off; 
    va_start(ap,e); 
    if((result=Locate(ap,off))<=0)return result; 
    e=*(base+off); 
    return OK; 
  }//Value 
   
  Status Assign(ElemType e,...)  //A是n维数组,e为元素变量,随后是n各下表值。 
                  //若各下标不越界,则将e的值付给所指定的A的元素,并返回OK。 
  { 
    va_list ap; 
    int result,off; 
    va_start(ap,e); 
    if((result=Locate(ap,off))<=0)return result; 
    *(base+off)=e; 
    return OK; 
  }//Assign 
   
}Array; 
void ArrayCheck()//代码正误检验 
{ 
  int i,j,k; 
  Array A; 
  ElemType e; 
  A.InitArray(3,2,3,2); 
  printf("维度:%d\n总元素个数:%d\n各维维界:",A.dim,A.elemtotal); 
  for(i=0;i<A.dim;i++) 
    printf("%d ",A.bounds[i]); 
  puts(""); 
  for(i=0;i<A.bounds[0];i++) 
    for(j=0;j<A.bounds[1];j++) 
      for(k=0;k<A.bounds[2];k++) 
        A.Assign(i*100+j*10+k+111,i,j,k); 
  for(i=0;i<A.bounds[0];i++,puts("")) 
    for(j=0;j<A.bounds[1];j++,puts("")) 
      for(k=0;k<A.bounds[2];k++) 
        printf("%d ",(A.Value(e,i,j,k),e)); 
  A.DestroyArray(); 
  puts(""); 
} 
程序结果: 
维度:3 
总元素个数:12 
各维维界:2 3 2 
111 112 
121 122 
131 132 
 
211 212 
221 222 
231 232 

主函数:

int main() 
{ 
  #ifndef ONLINE_JUDGEW 
// freopen("1.txt","r",stdin); 
  freopen("2.txt","w",stdout); 
  #endif 
  int i,j,k; 
  int x,y,z,xx,yy; 
// init(); 
// for(scanf("%d",&cass);cass;cass--) 
// for(scanf("%d",&cas),cass=1;cass<=cas;cass++) 
// while(~scanf("%s",s)) 
// while(~scanf("%d%d",&n,&m)) 
  { 
    ArrayCheck(); 
  } 
  return 0; 
} 

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 数据结构之数组Array  # 数据结构之数组  # C语言数据结构之顺序数组的实现  # C++ 数据结构线性表-数组实现  # JavaScript数据结构之数组的表示方法示例  # C语言 数据结构之连续存储数组的算法  # Java数组模拟优先级队列数据结构的实例  # PHP中使用数组实现堆栈数据结构的代码  # 数据结构之数组翻转的实现方法  # 求出  # 下表  # 值为  # 则将  # 变长  # 维维  # 几个  # 数据结构  # 希望能  # 谢谢大家  # 头文件  # min  # comment  # define  # pragma  # PI  # math  # memory  # bitset  # set 


相关文章: 如何确认建站备案号应放置的具体位置?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  定制建站是什么?如何实现个性化需求?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  建站主机服务器选型指南与性能优化方案解析  如何通过NAT技术实现内网高效建站?  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  广州美橙建站如何快速搭建多端合一网站?  建站之星安装后如何配置SEO及设计样式?  如何用VPS主机快速搭建个人网站?  如何用PHP快速搭建高效网站?分步指南  制作公司内部网站有哪些,内网如何建网站?  在线制作视频的网站有哪些,电脑如何制作视频短片?  建站之星后台管理如何实现高效配置?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  C++时间戳转换成日期时间的步骤和示例代码  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  建站之星2.7模板:企业网站建设与h5定制设计专题  如何挑选优质建站一级代理提升网站排名?  安徽网站建设与外贸建站服务专业定制方案  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何通过IIS搭建网站并配置访问权限?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何在搬瓦工VPS快速搭建网站?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  金*站制作公司有哪些,金华教育集团官网?  如何在Windows 2008云服务器安全搭建网站?  如何配置FTP站点权限与安全设置?  电商网站制作公司有哪些,1688网是什么意思?  如何使用Golang安装API文档生成工具_快速生成接口文档  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  如何快速辨别茅台真假?关键步骤解析  导航网站建站方案与优化指南:一站式高效搭建技巧解析  家具网站制作软件,家具厂怎么跑业务?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  如何制作网站标识牌,动态网站如何制作(教程)?  ,网站推广常用方法?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  深圳网站制作的公司有哪些,dido官方网站?  如何在云服务器上快速搭建个人网站?  建站之星安装路径如何正确选择及配置?  如何用5美元大硬盘VPS安全高效搭建个人网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。