- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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])
您可能关注的文档
最近下载
- 清华大学2021-2022学年第1学期《线性代数》期末考试试卷(B卷)及标准答案.docx
- 实验一用自然电位曲线估计地层水矿化度.doc VIP
- 清华大学2021-2022学年第1学期《线性代数》期末考试试卷(A卷)及标准答案.docx
- 1.疾病分类与代码国家临床版1.1.xlsx VIP
- 《基础写作》网上形考任务五.docx VIP
- 最新 贾柱立 京剧剧本 月圆时 汉英版 第一幕.doc VIP
- 中职生的班会主题.pptx VIP
- 钢结构课设-轻型屋面三角形钢屋架 05G517.pdf VIP
- 小学数学长度单位换算专项练习题(每日一练,共63份).docx VIP
- 园区运营管理可视化.docx VIP
原创力文档


文档评论(0)