1、《高级语言程序设计》实验报告 班级: 学号: 姓名: 成绩: 实验6 数组程序设计 一、实验目得 1. 掌握一维数组与二维数组得定义、赋值与输入输出得方法。 2. 掌握字符数组与字符串函数得使用。 3. 掌握与数组有关得算法。 二、实验内容 1.改错题(在程序中画出错误得语句,将修改后得语句完整地写在该语句得右边。) (1)下列程序得功能为:为指定得数组输入10个数据,并求这些数据之与。纠正程序中存在得错误,以实现其功能。程序以文件名sy6_1、c保存。 该程序得输出结果: #include<
2、stdio、h>
void main
{int n=10,i,sum=0;
int a[n]; int a[10];
for(i=0;i<10;i++)
{
scanf("%d",a[i]); scanf("%d",&a[i]);
sum=sum+a[i];
}
printf("sum=%d\n",sum);
}
该程序得输出结果:
(2)下列程序得功能为:将字符串b连接到字符串a。纠正程序中存在得错误,以实现其功能。程序以文件名sy6_2、c保存。
#include
3、n( ) { char a[]="wel",b[]="e"; char a[20]="wel",b[]="e"; int i,n=0; while(!a[n]) n++; while(a[n] != '\0') n++; for(i=0;b[i]!='\0';i++) a[n+i]=b[i]; a[n+i]=’\0’; printf("%s\n",a); } (3)下列程序得功能为:找出一个二维数组中得鞍点,即该位置上得元素在该行上最大,在该列上最小。也可能没有鞍点。纠正程序中存在得错误,以实现其功能。程序以文件名sy
4、6_3、c保存。
#include 5、a[i][j]>max) if (a[i][j]>=max)
{
max=a[i][j];
maxj=j;
}
for (k=0,flag1=1;k 6、if (! flag2)
printf("\nThere is no saddle point in the Matrix\n");
}
2.程序填空题
(1)以下程序得功能就是:采用二分法在给定得有序数组中查找用户输入得值,并显示查找结果。补充完善程序,以实现其功能。程序以文件名sy6_4、c保存。
#include "stdio、h"
#define N 10
main
{
int a[ ]={0,1,2,3,4,5,6,7,8,9},k;
int low=0,high=N1,mid,find=0;
printf("请输入欲查找得值:\n");
sc 7、anf("%d",&k);
while (low<=high)
{
mid=(low+high)/2;
if(a[mid]==k)
{
printf("找到位置为:%d\n",mid+1);find=1;
}
if(a[mid]>k)
_ high=mid1 ;
else
_ low=mid+1_____;
}
if(!finD、 printf("%d未找到\n",k);`
}
(2)以下程序得功能就是:求3个字符串(每串不超过20个字符)中得最大者。补充完善程序,以实现其功能。程序以文件名sy6_5、c保存。
#include 8、 9、从键盘输入20个整数,统计非负数个数,并计算非负数之与。补充完善程序,以实现其功能。程序以文件名sy6_6、c保存。
#include 10、3.编程题(写出程序运行结果)
(1)从键盘输入10个数,用选择排序法将其按由大到小得顺序排序;然后在排好序得数列中插入一个数,使数列保持从大到小得顺序。程序以文件名sy6_7、c存盘。
#define N 11
#include 11、j++)
if(a[k]>a[j])
k=j;
if(k!=i)
{ t=a[k]; a[k]=a[i]; a[i]=t;}
}
printf("\n排序后:\n");
for(i=0;i 12、 //插入
printf("\n插入后:\n");
for(i=0;i 13、[j]);
for(i=0;i<2;i++)
for(j =0;j<3; j++)
scanf("%d",&b[i][j]);
for(i=0; i<2; i++)
for(j =0;j<3; j++)
c[i][j]=a[i][j]+b[i][j];
for( i=0;i<2;i++)
{ for(j=0;j<3;j++)
printf("%3d",c[i][j]);
printf("\n"); 14、
}
}
(3)从键盘输入一个字符串,删除其中某个字符。如输入字符串“abcdefededff”,删除其中得字符e,则输出得字符串为“abcdfddff”。程序以文件名sy6_9、c存盘。
//方法一:
#include 15、i++)
if (s[i]!=c)
s[j++]=s[i];
s[j]='\0';
puts(s);
}
//方法二:
#include






