实验项目数组样本Word文档格式.docx
- 文档编号:20886744
- 上传时间:2023-01-26
- 格式:DOCX
- 页数:14
- 大小:520.16KB
实验项目数组样本Word文档格式.docx
《实验项目数组样本Word文档格式.docx》由会员分享,可在线阅读,更多相关《实验项目数组样本Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。
经过编程和调试程序,加深对数组、字符数组和字符串函数应用的理解二、实验设备(环境)及要求
使用VisualC++6.0;
windows系列操作系统的环境。
三、实验内容与步骤(要求以”学号_姓名_题号”为名建立项目;
例项目名为:
_***_01)
1.运行下面的c程序。
运行结果:
2.运行下面的c程序:
1)从键盘输入字符串:
howareyou,观察结果。
2)将上述程序的第四行改成scanf(”%s”,str);
重新运行上述程序,观察输出结果有什么不同,为什么?
重新运行的结果:
用scanf输入时””会被看成"
\0"
终止
3)如果用%c格式输入输出字符串,程序应怎样修改?
根据用%c格式输入输出字符的特点,修改后的程序为:
3.改错
有一个3×
4的矩阵,要求输出其中值最大的元素的值,以及它的行号和列号。
#include<
stdio.h>
#defineM3
#defineN4
voidmain()
{
intmax,i,j,r=0,c=0;
inta[M][N]={{0,94,-10,218},{3,9,10,-81},{45,16,44,-99}};
max=a[0][0];
for(i=0;
i<
=2;
i++)
for(j=0;
j<
=3;
j++)
if(a[i][j]>
max)
{
max=a[i][j];
r=i;
c=j;
}
printf("
max=%d,hang=%d,lie=%d\n"
max,r,c);
}
4.改错
下面是用来将数组a中元素按升序排序后输出的源程序。
分析源程序中存在的问题,并对源程序进行修改,使之能争取完成任务。
源程序:
intmain()
voidsort(int[],int);
inta[10]={23,12,34,56,8,6,5,4,34,56};
inti,
sort(a,10);
10;
printf("
%6d"
a[i]);
printf("
\n"
);
return0;
voidsort(intb[],intn)
inti,j,t;
n-1;
n-i;
if(b[j]>
b[j+1])
t=b[j];
b[j]=b[j+1];
b[j+1]=t;
5.编一个程序,输入10个整数,统计并输出其中正数、负数和零的个数。
)
6.应用数组求Fabonacci数列的前40项(该数列前两项为1,以后各项均为前相邻两项之和)要求以每行8个输出。
7.用冒泡法对20个整数排序。
20个整数需要键盘键入。
8.用选择法对20个整数排序。
voidsort(intarry[],intn);
inta[10],i;
enterarray:
scanf("
%d"
&
a[i]);
thesortedarry:
%5d"
voidsort(intarry[],intn)
inti,j,k,t;
=n-1;
{
k=i;
for(j=i+1;
n;
if(arry[j]<
arry[k])
k=j;
t=arry[k];
arry[k]=arry[i];
arry[i]=t;
}
9.编程实现:
对任意一个一维数组,从中找出数组元素的最大值和最小值。
要求:
(1)数组为整型数组(10个元素)。
(2)使用scanf函数实现数组元素的输入。
在输入前给出必要的提示。
(3)输出时给出必要的说明,首先输出原始的10个元素,换行后输出最大值以及最大值在数组中的位置、最小值以及最小值在数组中的位置。
(4)如果现改为20个元素的数组,怎样修改程序?
修改程序后,运行程序进行检查。
如果需要数组元素不断改变,应怎样修改程序?
10.编写一个程序,从键盘读入数据,对一个3*4矩阵进行赋值,求其转置矩阵,然后输出原矩阵和转置矩阵。
11.编程实现”折半查找”的过程。
折半查找的处理过程是:
在一个数据已排好序的数组中,首先比较关键字与数组中间的元素,如果两者相等,则查找结束;
如果前者比后者小,则要查找的数据必然在数组的前半部,此后只需在数组的前半部中继续折半查找;
如果前者的数值比后者大,则要查找的数据必然在数组的后半部,此后只需在数组的后半部继续进行折半查找。
要求:
(1)设定一个数组存放20个数据,用赋初值的方法在程序中给出(假设这些数据已排序)。
(2)用scanf函数输入一个要找的数。
(3)对查找的结果给出相应的说明,如果找到该数,则给出该数是数组中第几个元素。
如果该数不在数组中,则输出”无此数”信息。
(4)任意输入一些数据,检查程序的正确性。
(5)修改程序,设定输入的数据是无序的,采用scanf函数的形式输入,首先要对这些无序的数据进行排序,然后再采用”折半查找”。
最后经过测试几组差别较大的数据检查程序的正确性。
(6)修改程序,改为函数调用的形式。
编写一个选择法排序函数,对无序数据进行排序;
编写一个查找函数对已排好序的数据进行查找。
在主函数中输入数据(无序),调用上述函数,输出结果。
string.h>
inta[10];
输入十个数\n"
=9;
scanf("
for(j=0;
for(k=0;
k<
=9-j;
k++)
if(a[k]>
a[k+1])
{
t=a[k];
a[k]=a[k+1];
a[k+1]=t;
}
排序后\n"
%4d"
a[j]);
输入i\n"
i);
if(i==a[4]&
&
i==a[5])
ended\n"
elseif(i<
a[4])
if(i==a[2])
该数为第三个\n"
elseif(i<
a[2])
if(i==a[1])
printf("
该数为第二个\n"
elseif(i==a[0])
该数为第一个\n"
elseif(i==a[3])
该数为第四个\n"
else
无次数\n"
else
if(i==a[8])
该数为第9个\n"
a[8])
if(i==a[7])
该数为第8个\n"
elseif(i==a[6])
该数为第7个\n"
四、分析与讨论
对上机实践结果进行分析,上机的心得体会。
五、教师评语
签名:
日期:
成绩
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 项目 数组 样本