实验四 数组(二).docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验四 数组(二)

实验四 数组(二) 实验目的 掌握一维字符数组的定义及初始化。 掌握一维字符数组元素的引用及其应用。 掌握二维数组的定义和初始化。 掌握二维数组元素的引用及其应用。 实验内容 题目1:输入十个人的姓名,并按升序输出。(用选择法或者冒泡法排序) 问题 Strcpy函数是完全将后一个代替前一个么? 源代码 #include stdio.h #include string.h int main() { char a[10][80],x[80]; int i,j; for(i=0;i10;i++) gets(a[i]); for(i=0;i9;i++) for(j=i+1;j10;j++) if(strcmp(a[i],a[j])0) { strcpy(x,a[j]); strcpy(a[j],a[i]); strcpy(a[i],x); } for(i=0;i10;i++)printf(\n%s,a[i]); return 0; } 程序流程图 实验结果 题目2:求两个矩阵的积。如: 运算规则为: 第i行第j列相乘得到结果矩阵中r[i][j]的值。比如: r[0][0] = 1*1+2*5+3*8=35; r[0][1] = 1*5+2*3+3*1=14; r[1][0] = 4*1+5*5+6*8=77; r[1][1] = 4*5+5*3+6*1=41; 要求: 1.数组的行数和列数不超过100。 2.输入第一行中,第一个正整数m,表示第一个矩阵的行数,输入第二个正整数n,表示第一个矩阵的列数,也即是第二个矩阵的行数,输入第三个正整数p,表示第二个矩阵的列数。 3.接下来的m*n个数是第一个矩阵中的数。 4.再接下来的n*p个数是第二个矩阵中的数。 5.输出计算结果,为一个m行,p列的矩阵。 问题 无 源代码 ?# includestdio.h ?int main() ?{ ? int a[100][100] ={0}; ? int b[100][100] = {0}; ? int c[100][100] = {0}; ? int i = 0,j = 0,k=0; ? int n = 0; ? int x=0,y=0,z=0; ? printf(请输入矩阵a的行数:); ? scanf(%d,x); ? printf(请输入矩阵a的列数:); ? scanf(%d,y); ? printf(请输入矩阵a,元素之间用Tab隔开:\n); ? for(i=0;ix;i++) ? { ? for(j=0;jy;j++) ? scanf(%d,a[i][j]); ? printf(\n); ? } ? printf(请输入矩阵b的行数:); ? scanf(%d,y); ? printf(请输入矩阵b的列数:); ? scanf(%d,z); ? printf(请输入矩阵b,元素之间用Tab隔开:\n); ? for(i=0;iy;i++) ? { ? for(j=0;jz;j++) ? scanf(%d,b[i][j]); ? printf(\n); ? } ? //jisuan ? for(i=0;ix;i++) ? for(j=0;jz;j++) ? for(k=0;ky;k++) ? c[i][j] += a[i][k]*b[k][j]; ? //output ? for(i = 0;i x;i++) ? { ? for(j = 0;j z;j++) ? printf(%d\t,c[i][j]); ? printf(\n); ? } ? return 0; ?} 程序流程图【必须有】 实验结果 题目3:求矩阵的鞍点。鞍点位置上的元素在该行中值最大,在该列中值最小。如下面矩阵的鞍点为35。 【输入】前两个数为行数和列数,其后是矩阵中的元素 【输出】如果没有鞍点,输出NO;如果有输出格式为:[值1,行下标1,列下标1], [值2,行下标2,列下标2]…… 问题 下标的输出转换。 源代码 #include stdio.h int main() { int a[100][100]; int m,n,i,j,sign; printf(input m and n:\n); scanf(%d%d,m,n); printf(请输入这个矩阵\n); for(i=0;im;i++) for(j=0;jn;j++) scanf(%d,a[i][j]); for(i=0;im;i++) { for(sign=0,j=1;jn;j++) if(a[i][sign]a[i][j])

文档评论(0)

zijingling + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档