(嚴蔚敏版)數組的順序存儲表示和實現代碼

#include<stdarg.h>
?#include<malloc.h> /* malloc()等 */
?#include<stdio.h> /* EOF(=^Z或F6),NULL */
?#include<stdlib.h> /* atoi() */
?#include<io.h> /* eof() */
?#include<math.h> /* floor(),ceil(),abs() */
?#include<process.h> /* exit() */
?/* 函數結果狀態代碼 */


?#define TRUE 1
?#define FALSE 0
?#define OK 1
?#define ERROR 0
?#define INFEASIBLE -1
?/* #define OVERFLOW -2 因為在math.h中已定義OVERFLOW的值為3,故去掉此行 */
?typedef int Status; /* Status是函數的類型,其值是函數結果狀態代碼,如OK等 */
?typedef int Boolean; /* Boolean是布爾類型,其值是TRUE或FALSE */


?typedef int ElemType;




?#define MAX_ARRAY_DIM 8 /* 假設數組維數的最大值為8 */
?typedef struct
?{
? ?ElemType *base; /* 數組元素基址,由InitArray分配 */
? ?int dim; /* 數組維數 */
? ?int *bounds; /* 數組維界基址,由InitArray分配 */
? ?int *constants; /* 數組映象函數常量基址,由InitArray分配 */
?}Array;




?Status InitArray(Array *A,int dim,...)
?{ /* 若維數dim和各維長度合法,則構造相應的數組A,并返回OK */
? ?int elemtotal=1,i; /* elemtotal是元素總值 */
? ?va_list ap;
? ?if(dim<1||dim>MAX_ARRAY_DIM)
? ? ?return ERROR;
? ?(*A).dim=dim;
? ?(*A).bounds=(int *)malloc(dim*sizeof(int));
? ?if(!(*A).bounds)
? ? ?exit(OVERFLOW);
? ?va_start(ap,dim);
? ?for(i=0;i<dim;++i)
? ?{
? ? ?(*A).bounds[i]=va_arg(ap,int);
? ? ?if((*A).bounds[i]<0)
? ? ? ?return UNDERFLOW; /* 在math.h中定義為4 */
? ? ?elemtotal*=(*A).bounds[i];
? ?}
? ?va_end(ap);
? ?(*A).base=(ElemType *)malloc(elemtotal*sizeof(ElemType));
? ?if(!(*A).base)
? ? ?exit(OVERFLOW);
? ?(*A).constants=(int *)malloc(dim*sizeof(int));
? ?if(!(*A).constants)
? ? ?exit(OVERFLOW);
? ?(*A).constants[dim-1]=1;
? ?for(i=dim-2;i>=0;--i)
? ? ?(*A).constants[i]=(*A).bounds[i+1]*(*A).constants[i+1];
? ?return OK;
?}


?Status DestroyArray(Array *A)
?{ /* 銷毀數組A */
? ?if((*A).base)
? ?{
? ? ?free((*A).base);
? ? ?(*A).base=NULL;
? ?}
? ?else
? ? ?return ERROR;
? ?if((*A).bounds)
? ?{
? ? ?free((*A).bounds);
? ? ?(*A).bounds=NULL;
? ?}
? ?else
? ? ?return ERROR;
? ?if((*A).constants)
? ?{
? ? ?free((*A).constants);
? ? ?(*A).constants=NULL;
? ?}
? ?else
? ? ?return ERROR;
? ?return OK;
?}


?Status Locate(Array A,va_list ap,int *off) /* Value()、Assign()調用此函數 */
?{ /* 若ap指示的各下標值合法,則求出該元素在A中的相對地址off */
? ?int i,ind;
? ?*off=0;
? ?for(i=0;i<A.dim;i++)
? ?{
? ? ?ind=va_arg(ap,int);
? ? ?if(ind<0||ind>=A.bounds[i])
? ? ? ?return OVERFLOW;
? ? ?*off+=A.constants[i]*ind;
? ?}
? ?return OK;
?}


?Status Value(ElemType *e,Array A,...) /* 在VC++中,...之前的形參不能是引用類型 */
?{ /* ...依次為各維的下標值,若各下標合法,則e被賦值為A的相應的元素值 */
? ?va_list ap;
? ?Status result;
? ?int off;
? ?va_start(ap,A);
? ?if((result=Locate(A,ap,&off))==OVERFLOW) /* 調用Locate() */
? ? ?return result;
? ?*e=*(A.base+off);
? ?return OK;
?}


?Status Assign(Array *A,ElemType e,...)
?{ /* ...依次為各維的下標值,若各下標合法,則將e的值賦給A的指定的元素 */
? ?va_list ap;
? ?Status result;
? ?int off;
? ?va_start(ap,e);
? ?if((result=Locate(*A,ap,&off))==OVERFLOW) /* 調用Locate() */
? ? ?return result;
? ?*((*A).base+off)=e;
? ?return OK;
?}




?void main()
?{
? ?Array A;
? ?int i,j,k,*p,dim=3,bound1=3,bound2=4,bound3=2; /* a[3][4][2]數組 */
? ?ElemType e,*p1;
? ?InitArray(&A,dim,bound1,bound2,bound3); /* 構造3*4*2的3維數組A */
? ?p=A.bounds;
? ?printf("A.bounds=");
? ?for(i=0;i<dim;i++) /* 順序輸出A.bounds */
? ? ?printf("%d ",*(p+i));
? ?p=A.constants;
? ?printf("\nA.constants=");
? ?for(i=0;i<dim;i++) /* 順序輸出A.constants */
? ? ?printf("%d ",*(p+i));
? ?printf("\n%d頁%d行%d列矩陣元素如下:\n",bound1,bound2,bound3);
? ?for(i=0;i<bound1;i++)
? ?{
? ? ?for(j=0;j<bound2;j++)
? ? ?{
? ? ? ?for(k=0;k<bound3;k++)
? ? ? ?{
? ? ? ? ?Assign(&A,i*100+j*10+k,i,j,k); /* 將i*100+j*10+k賦值給A[i][j][k] */
? ? ? ? ?Value(&e,A,i,j,k); /* 將A[i][j][k]的值賦給e */
? ? ? ? ?printf("A[%d][%d][%d]=%2d ",i,j,k,e); /* 輸出A[i][j][k] */
? ? ? ?}
? ? ? ?printf("\n");
? ? ?}
? ? ?printf("\n");
? ?}
? ?p1=A.base;
? ?printf("A.base=\n");
? ?for(i=0;i<bound1*bound2*bound3;i++) /* 順序輸出A.base */
? ?{
? ? ?printf("%4d",*(p1+i));
? ? ?if(i%(bound2*bound3)==bound2*bound3-1)
? ? ? ?printf("\n");
? ?}
? ?DestroyArray(&A);
? ?system("PAUSE");
?}
?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/453338.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/453338.shtml
英文地址,請注明出處:http://en.pswp.cn/news/453338.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

特殊權限

2.18特殊的權限set_uid [rootcentos-01 ~]# which passwd //查詢一下passwd位置// /usr/bin/passwd[rootcentos-01 ~]# ls -l /usr/bin/passwd //查詢一下passwd權限//-rwsr-xr-x. 1 root root 27832 6月 …

我的職場戰爭--一年來的開發組內戰實錄

一 戰爭準備階段 一年前&#xff0c;國內分社派我帶著幾名程序員來到日本&#xff0c;進入一個世界級大公司做項目&#xff0c;這里先期駐在了一個日本總社的社員X。沒有人想到戰爭已經臨近。 二 戰爭醞釀階段 日本人不會叫你閑著&#xff0c;頭一個月就開始了下馬威。…

linux8重啟服務代碼,linux(centos8):安裝分布式事務服務seata(seata 1.3.0/centos 8.2)

一&#xff0c;什么是seata?Seata:Simpe Extensible Autonomous Transcaction Architecture&#xff0c;是阿里中間件,開源的分布式事務解決方案。前身是阿里的Fescar官方站:http://seata.io/zh-cn/官方代碼地址:https://github.com/seata/seata官方文檔站:http://seata.io/zh…

數組與矩陣的區別

數組中的元素可以是字符等 矩陣中的只能是數 這是二者最直觀的區別。 因為矩陣是一個數學概念&#xff08;線性代數里的&#xff09;&#xff0c;數組是個計算機上的概念。 《精通MATLAB6.5版》&#xff08;張志涌編著&#xff0c;北京航空航天大學出版社&#xff09;中說&…

android自定義view(自定義數字鍵盤)

序言&#xff1a;在上周的項目中&#xff0c;需要做一個密碼鎖的功能&#xff0c;然后密碼下面還得有鍵盤&#xff0c;就類似支付寶支付的時候那樣&#xff1a; 當然了&#xff0c;我們項目的需求簡單點&#xff0c;純數字的就可以了&#xff0c;然后上周就百度了自定義鍵盤&am…

linux環境部署ltmj,Linux系統安裝與簡單配置 圖文.docx

合肥師范學院實驗報告姓名:課程名稱&#xff1a;Linux院(系&#xff1a;計算機學院 專業/年級:實於Lin^系繚公裝與苗瑕肚卅1.占克If Jf VVVork51at>un ?- If -JpMHIWortsktKia^2.?JGJiIjxiS4CLM.lt 1H. iuFI?H?*vW ?tVirtujl Machine Wisa rdGimm Oprraimv加薊aBMkonA …

矩陣的壓縮存儲

5.3 矩陣的壓縮存儲 矩陣是很多科學與工程計算問題中研究的數學對象&#xff0c;在此&#xff0c;我們討論如何存儲矩陣的元&#xff0c;從而使矩陣的各種運算能有效第進行。對于一個矩陣結構顯然用一個二維數組來表示是非常恰當的&#xff0c;但在有些情況下&#xff0c;比如常…

網絡工程師還要學linux嗎,網絡工程師要學什么

想成為一個優秀的網絡工程師&#xff0c;要學什么&#xff0c;怎么學呢?今天小編帶你了解一下網絡工程師到底要學什么。上篇我們講到了“網絡工程師發展方向”&#xff0c;列舉了許多技術方向&#xff0c;那么我們該如何根據自己的定位選擇學習哪些技術。重點是哪些&#xff0…

利用FormData對象實現AJAX文件上傳功能及后端實現

包括HTML基礎設置、CSS界面優化、JS利用FormData對象和AJAX進行上傳、后端接收文件并存儲到指定路徑以及刪除文件操作。FE HTML 基礎的設置&#xff1a; <form enctype"multipart/form-data"><input id"file" type"file" multiple"…

第 6 章 —— 裝飾模式

6.6 裝扮模式總結 裝飾模式把每個要裝飾的功能放在單獨的類中&#xff0c;并讓這個類包裝它所要裝飾的對象&#xff0c;因此&#xff0c;當需要執行特殊行為時&#xff0c;客戶端代碼就可以在運行時根據需要有選擇地、按順序地使用裝飾功能包裝對象了。 裝扮模式是為已有功能動…

廣義表及其存儲方式簡介

廣義表&#xff08;Lists&#xff0c;又稱列表&#xff09;是線性表的推廣。線性表定義為n>0個元素a1,a2,a3,…,an的有限序列。線性表的元素僅限于原子項&#xff0c;原子是作為結構上不可分割的成分&#xff0c;它可以是一個數或一個結構&#xff0c;若放松對表元素的這種限…

Vue.js:路由

ylbtech-Vue.js&#xff1a;路由1.返回頂部 1、Vue.js 路由 本章節我們將為大家介紹 Vue.js 路由。 Vue.js 路由允許我們通過不同的 URL 訪問不同的內容。 通過 Vue.js 可以實現多視圖的單頁Web應用&#xff08;single page web application&#xff0c;SPA&#xff09;。 Vue.…

圖片轉excel:“保留數字格式”在什么場景下該勾

保留數字格式是什么意思呢&#xff1f;顧名思義&#xff0c;就是將轉出來的數字保留為數字格式&#xff0c;而不是文本格式。我們知道&#xff0c;OCR程序將圖片上的文字識別為電腦可編輯的文字后&#xff0c;如果導入到excel不加處理&#xff0c;則單個數字過長的文字就會被ex…

html概述和基本結構

html概述 HTML是 HyperText Mark-up Language 的首字母簡寫&#xff0c;意思是超文本標記語言&#xff0c;超文本指的是超鏈接&#xff0c;標記指的是標簽&#xff0c;是一種用來制作網頁的語言&#xff0c;這種語言由一個個的標簽組成&#xff0c;用這種語言制作的文件保存的是…

linux添加三權,基于SELinux的三權分離技術的研究

目前&#xff0c;Linux操作系統已廣泛應用于各種設備和產品中&#xff0c;如服務器、PC機、機頂盒及路由器等。隨著Linux系統的不斷發展和廣泛應用&#xff0c;Linux系統的安全問題也引起越來越多的關注。在Linux操作系統中&#xff0c;存在一個超級用戶即root用戶。root也稱為…

二叉樹、樹和有序樹的區別

樹&#xff1a;子樹沒有左右之分 二叉樹、有序樹:左右有序 二叉樹與有序樹&#xff1a;在只有一棵樹的情況下&#xff0c;二叉樹有左右之分、有序樹無左右之分 另外&#xff1a;二叉樹是有序的&#xff0c;可以為空或一個根節點以及兩個分別稱為左子樹和右子樹的互不相交的二叉…

高效程序員

軟件開發人員的作戰手冊 - 讓程序員活的久一點 1. 程序員的職業準則是&#xff1a;誠實&#xff08;如實的報告你的狀態&#xff0c;風險和出現的問題&#xff09;&#xff0c;守信&#xff08;承諾完成的任務就要按時完成&#xff09;&#xff0c;尊重&#xff08;尊重給你的代…

PHP學習筆記1

1.什么是PHP&#xff1f; Hypertext Preprocessor(超文本預處理語言)。 是腳本語言。 是最流行的網站開發語言。 2.PHP能做什么&#xff1f; 可以生成動態頁面內容。 可以創建、打開、讀取、寫入、關閉服務器上的文件。 可以手機表單數據。 可以發送和接收cookies。&#xf…

Redis在windows下的配置

原文:Redis在windows下的配置 Redis在windows下的配置&#xff08;在windows-64下安裝redis&#xff0c;請參考微軟redis的github&#xff1a;https://github.com/MSOpenTech/redis/releases&#xff09;下面是windows32的配置 下載地址http://files.cnblogs.com/files/cuiweny…

linux磁盤符變化autofs,Linux基礎教程學習筆記之Autofs自動掛載

Linux基礎教程學習筆記之Autofs自動掛載Autofs自動掛載&#xff1a;yum -y install autofsvim /etc/auto.master 在文件中添加下面行/home/guests /etc/auto.tianyunvim /etc/auto.tianyun 子掛載點監控ldapuser0 -rw,sync classroom:/home/guests/ldapuser0systemctl enable …