第4章数组课后作业2014

合集下载

数据结构第4章 数组和广义表

数据结构第4章  数组和广义表

第4章数组和广义表【例4-1】二维数组A的每一个元素是由6个字符组成的串,其行下标i=0,1,…,8,列下标j=1,2,…,10。

若A以行为主序存储元素,A[8][5]的物理地址与当A按列为主序存储时的元素()的物理地址相同。

设每个字符占一个字节。

A.A[8][5] B.A[3][10] C.A[5][8] D.A[0][9]解:二维数A是一个9行10列的矩阵,即A[9][10]。

按行存储时,A[8][5]是第85个元素存储的元素。

而按列存储时,第85个存储的元素是A[3][10]。

即正确答案为B。

【例4-2】若对n阶对称矩阵A以行序为主序方式将其下三角形的元素(包括主对角线上所有元素)依次存放于一维数组B[n(n+1)/2]中,则在B中确定的位置k的关系为()。

A.jii+-2)1(*B.ijj+-2)1(*C.jii++2)1(*D.ijj++2)1(*解:如果a ij按行存储,那么它的前面有i-1行,其有元素个数为:1+2+3+…+(i-1)=i(i-1)/2。

同时它又是所在行的第j列,因此它排列的顺序还得加上j,一维数组B[n(n+1)/2]中的位置k与其下标的关系是:jii+-2)1(*。

因此答案为A。

【例4-3】已知n阶下三角矩阵A,按照压缩存储的思想,可以将其主对角线以下所有元素(包括主对角线上元素)依次存放于一维数组B中。

请写出从第一列开始以列序为主序分配方式时在B中确定元素a ij的存放位置的公式。

解:如果a ij按列存储,那么它的前面有j-1列,共有元素:n+(n-1)+(n-2)+ …+[n-(j-2)]=(j-1)*n-2)1)(2(--jj而它又是所在列的第i行,因此在它前的元素个数还得加上i。

因此它在一维数组B中的存储顺序为:(j-1)*n-2)1)(2(--jj+i【例4-4】已知广义表L=((x,y,z),a,(u,t,w)),从L表中取出的原子项ASCII码最大的运算是()。

程序设计基础-c语言-第四章数组-教材答案-科学出版社

程序设计基础-c语言-第四章数组-教材答案-科学出版社

程序设计基础-c语言-第四章数组-教材习题及其答案1.0编程将一个一维数组的值按逆序重新存放#include<stdio.h>void main(){int i_data[10];int m,i_temp;printf("给定10个数,用空格分隔:");scanf("%d %d %d %d %d %d %d %d %d %d",&i_da ta[0],&i_data[1],&i_data[2],&i_data[3],&i_data[4],&i_d ata[5],&i_data[6],&i_data[7],&i_data[8],&i_data[9]);for(m=1;m<=10/2;m++) //有意写成10/2 已解决任意一维数组的逆序问题,为什么此处用m=1;m<=10/2,而不能m=0;m<10/2{ i_temp=i_data[m-1]; //下面三条语句是典型的两数交换的方法i_data[m-1]=i_data[10-m];i_data[10-m]=i_temp;}for(m=0;m<10;m++){ printf("%d ",i_data[m]);}printf("\n");}2.0 编程求Fibonacci数列的前二十项。

FIBONACCI数列的定义F0=0,F1=1,Fn=Fn-1+Fn-2#include<stdio.h>void main(){int F[20];int m,n,i_blanknum;for(m=0;m<20;m++){ switch(m){ case 0:F[0]=0;break;case 1:F[1]=1;break;default: F[m]=F[m-1]+F[m-2];}}printf("Fibonacci数列的前20项是:\n"); for(m=0;m<20;m++){ printf("%d ",F[m]);}printf("\n");//下面输出项,这是我加的效果for(m=0;m<20;m++){ printf("%d",m+1); //输出项的编号//计算该项数据占几位i_blanknum=1;//每个数据间占一个空格n=F[m];do{ i_blanknum=i_blanknum+1;n=n/10;}while(n!=0);//减去该项编号数据占的位数n=m+1;do{ i_blanknum=i_blanknum-1;n=n/10;}while(n!=0);//输出空格while(i_blanknum>0){ printf(" ");i_blanknum--;}}printf("\n");}2.0在一个从小到大排列的数组中查找X,若x存在就将其测出,若不存在将其添加。

第四、五章串、数组和广义表练习题答案

第四、五章串、数组和广义表练习题答案

第四、五章串、数组和广义表练习题答案一.填空题1. 不包括任何字符(长度为0)的串称为空串;由一个或多个空格(仅由空格符)组成的串称为空白串。

2. 设S=“A;/document/”,那么strlen(s)= 20 , “/”的字符定位的位置为3。

3. 子串的定位运算称为串的模式匹配;被匹配的主串称为目标串,子串称为模式。

4. 设目标T=”abccdcdccbaa”,模式P=“cdcc”,那么第 6 次匹配成功。

5. 假设n为主串长,m为子串长,那么串的古典(朴素)匹配算法最坏的情形下需要比较字符的总次数为(n-m+1)*m。

6. 假设有二维数组A6×8,每一个元素用相邻的6个字节存储,存储器按字节编址。

已知A的起始存储位置(基地址)为1000,那么数组A的体积(存储量)为 288 B ;末尾元素A57的第一个字节地址为 1282 ;假设按行存储时,元素A14的第一个字节地址为(8+4)×6+1000=1072 ;假设按列存储时,元素A47的第一个字节地址为 (6×7+4)×6+1000)=1276 。

(注:数组是从0行0列仍是从1行1列计算起呢?由末单元为A57可知,是从0行0列开始!)7. 〖00年运算机系考研题〗设数组a[1…60, 1…70]的基地址为2048,每一个元素占2个存储单元,假设以列序为主序顺序存储,那么元素a[32,58]的存储地址为8950 。

答:不考虑0行0列,利用列优先公式:LOC(a ij)=LOC(a c1,c2)+[(j-c2)*(d1-c1+1)+i-c1)]*L得:LOC(a32,58)=2048+[(58-1)*(60-1+1)+32-1]]*2=89508. 三元素组表中的每一个结点对应于稀疏矩阵的一个非零元素,它包括有三个数据项,别离表示该元素的行下标、列下标和元素值。

9.求以下广义表操作的结果:(1)GetHead【((a,b),(c,d))】=== (a, b) ; u=;(*b).nu=;(*b).tu=;if{ q=1;for(col=1; __ col<=, ________;col++)for(p=1;p<=;p++)if[p].j ==col){(*b).data[q].i=[p].j;(*b).data[q].j=[p].i;(*b).data[q].v=[p].v;__q++_________;}}23.基于三元组的稀疏矩阵转置的处置方式有两种,以下计算依照矩阵A的三元组的顺序进行转置,请在___________处用适当的句子用以填充。

第4章 java课后作业_数组

第4章 java课后作业_数组

第4张课后作业_数组知识点:一维数组、二维数组一、填空及选择:1.数组元素的小标总是从___0___开始。

2.对于数组int[][]={{1,2,3},{4,5,6}}来说,t.length等于__2____,t[0].length等于___3__。

3.已知数组a的定义为“int a[]={1,2,3,4,5};”,则a[2]=__3__,数组b的定义为“int b[]=newint[5];”,则b[2]=__ 0___,数组c的定义为“Object [] c=new Object[5];”,则c[2]=_____。

4.调用数组元素时,用__数组名__和__元素下标___来唯一确定数组中的元素。

5.下列___C__语句有错误A.int [] a;B.int [] b=new int[10];C. int []c=new int[];D.int d[]=null;6.下列___D__语句有错误A.int a[][]=new int[5][5];B.int [][] b=new int[5][5];C.int []c[]=new int[5][5];D.int [][]d=new int[5,5];7.关于下面的程序,正确的结论是___A__public class Demo1{public static void main(String [] args){int a[]=new int[5];boolean b[]=new boolean[5]; //布尔值自动初始化为falseSystem.out.println(a[1]);System.out.println(b[2]);}}A.运行结果为0 falseB.运行结果为1 trueC.程序无法编译D.可以通过编译但结果不确定二、编程题:1.定义一个整数定义的数组,求奇数个数和偶数个数。

2.用20个整数初始化数组,只是输出前10个数。

用break控制3.计算10~20的整数的平方值,将结果保存在一个数组中。

第四章 数组作业

第四章 数组作业

第四章数组4.1 选择题1. 以下关于数组的描述正确的是( )。

A. 数组的大小是固定的,但可以有不同的类型的数组元素B. 数组的大小是可变的,但所有数组元素的类型必须相同C. 数组的大小是固定的,所有数组元素的类型必须相同D. 数组的大小是可变的,可以有不同的类型的数组元素2. 以下对一维整型数组a的正确说明是( )。

A.int a(10);B. int n=10,a[n];C.int n;D. #define SIZE 10scanf("%d",&n); int a[SIZE];int a[n];3. 在C语言中,引用数组元素时,其数组下标的数据类型允许是( )。

A. 整型常量B. 整型表达式C. 整型常量或整型表达式D. 任何类型的表达式4. 以下对一维数组m进行正确初始化的是( )。

A. int m[10]=(0,0,0,0) ;B. int m[10]={ };C. int m[ ]={0};D. int m[10]={10*2};5. 若有定义:int bb[ 8];。

则以下表达式中不能代表数组元bb[1]的地址的是( )。

A. &bb[0]+1B. &bb[1]C. &bb[0]++D. bb+16. 假定int类型变量占用两个字节,其有定义:int x[10]={0,2,4};,则数组x在内存中所占字节数是( )。

A. 3B. 6C. 10D. 207. 若有以下说明:int a[12]={1,2,3,4,5,6,7,8,9,10,11,12};char c='a',d,g;则数值为4的表达式是( )A. a[g-c]B. a[4]C. a['d'-'c']D. a['d'-c]8. 以下程序段给数组所有的元素输入数据,请选择正确答案填入( )。

#include<stdio.h>main(){int a[10],i=0;while(i<10) scanf("%d",________ );┇}A. a+(i++)B. &a[i+1]C. a+iD. &a[++i]9. 执行下面的程序段后,变量k中的值为( )。

C 课后习题答案第四章

C  课后习题答案第四章
case 'b' : cout << '$' ; break ;
case 'c' : cout << '*' ; break ;
case 'd' : continue ;
}
cout << '#' << endl ;
}
}
答案:
$#
*#
*#
%
7.#include <iostream.h>
void main()
#include <iostream.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
int isPrime(int);
void createAry(int[], int);
void outAry(const int[], int);
void main()
cout << f( a, 3, 3 ) << endl ;
}
int f( int a[][3], int row, int col )
{int i, j, t=1 ;
for( i=0; i<row; i ++ )
for( j=0; j<col; j++ )
{a[i][j] ++ ;
if( i == j ) t*= a[i][j] ;
}
void createAry(int a[], int n)
{ srand( time(0) );

6.C语言第四章数组(1)


4.1.4 一维数组程序举例
【例4-2】 从键盘输入10个整数,求出它们的平均值 及比平均值大的数。 #include<stdio.h> void main( ) { int i , x[10]; float sum=0,aver=0.0; for (i=0;i<10;i++) {scanf("%d",&x[i]); sum=sum+x[i]; } aver=sum/10.0;
4.2.4 二维数组程序举例
#include<stdio.h> printf("\n array b:\n"); void main( ) for(i=0;i<3;i++) { int a[3][4], b[3]; printf("%5d",b[i]); int i,j,max; printf("\n"); for(i=0;i<3;i++) } for(j=0;j<4;j++) 运行结果: scanf("%d",&a[i][j]); 25 88 69 72↙ for(i=0;i<3;i++) 33 29 78 96↙ { b[i]=a[i][0]; 9 54 48 90↙ for(j=1;j<4;j++) array b: if(a[i][j]>b[i]) 88 96 90 b[i]=a[i][j]; }
4.2.1 二维数组的定义
例如,可以把x看作是一个一维数组,它有3 个元素:x[0]、x[1]、x[2];而x[0]、x[1]、x[2] 又可以看作是三个一维数组的名字。其中,x[0] 由x[0][0]、x[0][1]、x[0][2]三个元素组成;x[1] 由x[1][0]、x[1][1]、x[1][2]三个元素组成;x[2] 由x[2][0]、x[2][1]、x[2][2]三个元素组成。即: x[0]: x[0][0] x[0][1] x[0][2] x x[1]: x[1][0] x[1][1] x[1][2] x[2]: x[2][0] x[2][1] x[2][2] 注意,二维数组和一维数组一样,数组元素 的下标从0开始,因此x的下标最大的元素是 x[2][2],而不是x[3][3]。

第4-5章习题带答案

第4章数组一、单选题1、若有定义:int aa[8];,则不能代表数组元素aa[1]地址的是()。

A. &aa[0]++B. &aa[1]C. &aa[0]+1D. aa+12、以下定义语句中,错误的是()。

A. int a[]={1,2};B. char *a[3];C. char s[10]="test";D. int n=5,a[n];3、设有定义:int a[10],*p=a;,对数组元素的正确引用是()。

A. a[p]B. *(p+2)C. p[a]D. p+24、若有如下定义,则不能表示数组a元素的表达式是()。

int a[10]={1,2,3,4,5,6,7,8,9, 10},*p=a;A. *pB. *aC. a[p-a]D. a[10]5、设有定义:int a[]={1,5,7,9,11,13},*p=a+3;,则*(p-2)与*(a+4)的值分别是()。

A. 5 9B. 1 9C. 5 11D. 有错误6、有以下语句,则对a数组元素的引用不正确的是(0≤i≤9)()。

int a[10]={0,1,2,3,4,5,6,7,8, 9},*p=a;A. a[p-a]B. *(&a[i])C. *(*(a+i))D. p[i]7、若有如下定义,则b的值是()。

int a[10]={1,2,3,4,5,6,7,8,9, 10},*p=&a[3],b=p[5];A. 9B. 6C. 8D. 58、设有定义:int a[10],*p=a+6,*q=a;,则下列运算哪种是错误的()。

A. p-qB. p+qC. p+3D. p>q9、下列程序的输出结果是()。

main(){ char a[10]={9,8,7,6,5,4,3,2,1, 0},*p=a+5;printf("%d",*--p);}A. 运行出错B. a[4]的地址C. 3D. 510、运行下列程序的输出结果是()。

数据结构第4章作业参考答案

第4章(数组和广义表)作业参考答案一、单项选择题1.将一个A[1..100,1..100]的三对角矩阵,按行优先压缩存储到一维数组B[1‥298]中,A 中元素A[66][65]在B数组中的位置K为(C )。

A. 198B. 197C. 195D. 1962.广义表(a,(b,c),d,e)的表头为( A )。

A. aB. a,(b,c)C. (a,(b,c))D. (a)3.在三对角矩阵中,非零元素的行标i和列标j的关系是( A )。

A. |i-j|≤1B. i>jC. i==jD. i<j4.广义表L=(a,(b,c)),进行Tail(L)操作后的结果为( D )。

A. cB. b,cC.(b,c)D.((b,c))5.设二维数组A[1..m,1..n](即m行n列)按行存储在数组B[1..m*n]中,则二维数组元素A[i,j]在一维数组B中的下标为( D )。

A. j*m+i-1B. (i-1)*n+j-1C. i*(j-1)D. (i-1)*n+j6.广义表(( ),( ),( ))的深度为( C )。

A. 0B. 1C. 2D. 37.假设以行序为主序存储二维数组A[0..99,0..99],设每个数据元素占2个存储单元,基地址为10,则LOC(A[4][4])=( C )。

A. 1020B. 1010C. 818D. 8088.已知广义表A=((a,b),(c,d)),则head(A)等于( A )。

A. (a,b)B. ((a,b))C. a,bD. a9.已知一个稀疏矩阵的三元组表如下:(1,2,3),(1,6,1),(3,1,5),(3,2,-1),(4,5,4),(5,1,-3)则其转置矩阵的三元组表中第3个三元组为( C )。

A. (2,3,-1)B. (3,1,5)C. (2,1,3)D. (3,2,-1)10.广义表((b,c),d,e)的表尾为( C )。

计算机基础与程序设计第四章习题答案

第四章课后习题一、选择题1、有定义语句:int [,]a=new int[5,6];,则下列正确的数组元素的引用是()。

A.a(3,4)B.a(3)(4)C.a[3][4]D.a[3,4]2、下列的数组定义语句,不正确的是()。

A.int a[]=new int [5]{1,2,3,4,5};B. int[,]a= new int a[3][4];C. int [][]a=new int [3][];D.int[]a={1,2,3,4};3、数组定义与赋初值语句如下:int [ ]a={1,2,3,4,5}; 则a[2]的值为()。

A.2B.3C.4D.14、下列数组定义语句中,int []a= new int[3]; 定义的数组a占的字节数为()。

A.16B.12C.6D.85、下列数组定义语句中,double [,]d=new int[4,5];则定义的数组d占的字节数为()。

A.160B.80C.240D.1206、下列程序段执行后,int []a={1,2,3,4,5}; a[4]=a[a[2]]; 则a[4]的值为()。

A.2B.3C.4D.57.要定义一个3行4列的单精度型二维数组f,使用的定义语句为()。

A.float f [,]=new float [3,4];B.float [,]f=new float[3][4];C.float [,];D.float [,]f=new float [3,4];8、语句如下:int[]c1=new int[5];int[] c2={1,2,3,4,5,6,7,8,9,0};数组c1和c2中的元素的个数分别为()A.6和10B. 6和9C. 5和10D. 5和99、定义一个数组,正确的代码为()A.int arraya[]=new int[5];B.int[] arraya=new int[5];C.int arraya=new int;D.int[5] arraya=new int[5];10、要定义一个为int型的交错数组a,数组有两行,第一行一个元素,第二行两个元素并赋初值3和4,使用的语句是()A.int [ ][ ]a=new int[2][ ];a[1]=new int[1];a[2]=new int[2]{3,4};B.int [ ][ ]a=new int[2][ ];a[0]=new int[1];a[1]=new int[2]{3,4};C.int [][]a=new int[ ][ ];a[0]=new int[1];a[1]=new int[2]{3,4};D.int [ ][ ]a=new int[ ][2];a[0]=new int[1];a[1]=new int[2]{3,4};11、下列代码的运行结果()int[] age1 = new int[] { 10, 20 };int[] age2 = age1;age2[1] = 30;Console.WriteLine(age1[1]);Console.ReadKey();A.0B.10C.20D.3012、定义并初始化一个用于存放我们国家的四个直辖市的数组cityName,四个直辖市为:北京,上海,天津,重庆. 正确的是( ABC )多选A.String[] cityName = new String[4] { “北京”, “上海”, “天津”, “重庆" };B.String[] cityName = new String[] { “北京”, “上海”, “天津”, “重庆" };C.String[] cityName={“北京”,”上海“,”天津“,”重庆"};D.String cityName = new String[4] { “北京”, “上海”, “天津”, “重庆" };三、编写程序题1、编写一个Windows应用程序,随机产生10个两位整数存放在数组中,找出最大值、最小值、高于平均值的数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第4章数组
一、选择题
1.如下数组定义语句,正确。

(A)int a[3,4]; (B)int n=3,m=4,int a[n][m];
(C)int a[3][4] ; (D)int a(3)(4);
2.以下不能对二维数组a初始化的语句是。

(A)int a[2][]={{1},{2}}; (B)int a[2][3]={1,2,3,4,5,6};
(C)int a[2][3]={1}; (D)int a(2)(3)={3,4,5,6,7,8};;
3.要使字符数组str具有初值"Lucky",正确的定义语句是。

(A)char str[]={‘L’,’u’,’c’,’k’,’y’}; (B)char str[5]={‘L’,’u’,’c’,’k’,’y’};
(C)char str []="Lucky"; (D) char str [5]="Lucky";
4.要比较两个字符数组a,b中字符串是否相等,下面正确。

(A)a==b (B)strcmp(a,b)==0
(C)strcpy(a,b)(D)SCtring s1=a,s2=b;
s1==s2;
二、阅读程序,写出运行结果
若分别输入4和8,则以下程序的输出结果各是什么?
#include <iostream>
using namespace std;
int main()
{
char b[17]="0123456789ABCDEF";
int i=0, h,n, c[10]; long m;
cin>>m>>h;
do
{
c[i++]=m%h;
}while((m=m/h)!=0);
for(--i; i>=0; --i)
{
n=c[i]; cout<<b[n];
}
return 0;
}
三、程序填空
1.已知数组a和b都是按由小到大顺序排列的有序数组,试将其合并后放入数组c中,使c也按由小到大顺序排列。

#include<iostream>
using namespace std;
#define M 10
#define N 10
int main()
{
int a[M], b[N], c[M+N], j, k, l;
for(k=0; k<M; k++) cin>>a[k];
for(k=0; k<N; k++) cin>>b[k];
_______________;
while(l<M+N && ______________)
{
if(a[j]<b[k])
{ ____________;
j++;
}
else
{ ____________;
k++;
}
l++;
}
while(l<M+N &&_______) c[l++]=b[k++];
while(l<M+N&&________) c[l++]=a[j++];
for(l=0; l<M+N; l++) cout<<c[l]<<’’;
return 0;
}
2.下列程序将数组a中的每四个相邻元素的平均值存放于数组b中。

#include <iostream>
using namespace std;
int main()
{
int a[10], m, n;
float b[7];
for(m=0; m<10; m++) cin>>a[m];
for(m=0; m<7; m++)
{ _______;
for(n=m; ________; n++)
b[m]=b[m]+a[n];
___________;
}
for(m=0; m<7; m++) cout<< b[m]<<endl;
return 0;
}
四、绘制流程图及编写程序
1.将给定的一数插入到有序的数组中。

【思路】
(1)找出被插入值所在的位置;
(2)从该位置起到最后的所有元素右移一位;
(3)将被插入数值放入空出的位置。

2.对n个数按升序排序。

(选择法)
【基本步骤】
(1)将无序序列中的n个数据扫描一次,找到最小数,将它放在第1个位置上。

(2)在无序序列剩余的n-1个数中找到最小数,将它放在第2个位置上。

(3)在无序序列剩余的n-2个数中找到最小数,将它放在第3个位置上。

……
3.利用二维数组存储杨辉三角形的前10行。

【要求】按如下形式打印杨辉三角形:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
1 6 15 20 15 6 1
1 7 21 35 35 21 7 1
1 8 28 56 70 56 28 8 1
1 9 36 84 126 126 84 36 9 1。

相关文档
最新文档