预备实验C语言的函数数组指针结构体知识
一、实验目的
1、复习C语言中函数、数组、指针、结构体与共用体等的概念。
2、熟悉利用C语言进行程序设计的一般方法。
二、实验预习
说明以下C语言中的概念
1、函数:
2、数组:
3、指针:
4、结构体
5、共用体
6、给下面一段代码加注释
#include<stdio.h>
#defineok1
#defineerror0
#defineMAXSIZE100/*顺序表的容量*/
typedefintElemType;
typedefstruct
{
ElemTypeelem[MAXSIZE];/*存放顺序表的元素*/
intlast;/*顺序表的最后一个元素的下标*/
}SqList;
typedefstruct
{
ElemType*elem;/*存放顺序表的元素*/
intlength;/*顺序表的实际长度*/
}SqList;
三、实验内容和要求
1、(1)调试以下程序:输出100以内所有的素数(用函数实现)。
#include<stdio.h>
#include<math.h>
intisprime(intn){/*判断一个数是否为素数*/
intm,;
for(m=2;m*m<=n;m++)//m<=sqrt(n)if(n%m==0)return0;
return1;
}
#include<stdio.h>
intmain(){/*输出100以内所有素数*/
inti,s=0;
printf("\n");
for(i=2;i<100;i++)
return0;
}
运行结果:
⑵模仿(1),编写程序,求1!+2!+3!+……+n!(n=10)要求阶乘用函数实现。#include<stdio.h>
intisfac(intn){/*求阶乘*/
intm,p=1;
for(m=2;m<=n;m++)//m<=sqrt(n)p=p*m;
returnp;
}
c语言指针实验总结intmain(){/*输出1!+2!+3!++n!(n=10)*/
inti,s=0;
printf("\n");
for(i=1;i<=10;i++)
s=s+isfac(i);
printf("%4d",s);
return0;
}
2、(1)调试程序:对一维数组中的元素进行逆序排列。
(2)修改所给的程序,设计三个函数:input(a)、output(a)、invert(a),分别实现一维数组的输入、输出和数据元素逆序排列运算,并在主函数中调用。
#include<stdio.h>
#defineN10
intmain(){
inta[N],i,temp;//={0,1,2,3,4,5,6,7,8,9}
printf("\ntheoriginalArrayis:\n");//输出原始数组元素0,1,2,3,4,5,6,7,8,9
for(i=0;i<N;i++)
scanf(“%d”,&a[i]);
for(i=0;i<N;i++)
printf("%4d",a[i]);
for(i=0;i<N/2;i++){/*交换数组元素使之逆序*/
temp=a[i];
a[i]=a[N-i-1];
a[N-i-1]=temp;
}
printf("\nthechangedArrayis:\n");//输出改变顺序后数组元素9,8,7,6,5,4,3,2,1,0
for(i=0;i<N;i++)
printf("%4d",a[i]);
return0;
}
(1)运行结果:
(2)运行结果:
#include<stdio.h>
#defineN10
voidinput(inta[]);
voidinvert(inta[]);
voidoutput(inta[]);
intmain(){
inta[N];
input(a);
output(a);
invert(a);
output(a);
return0;
}
voidinput(int*a){
intb[]={0,1,2,3,4,5,6,7,8,9},i;
for(i=0;i<N;i++)
*a++=b[i];
//inti;
//for(i=0;i<N;i++)
//scanf("%d",&a[i]);printf("\n");return;
}
voidoutput(int*a){
inti;
printf("\nTheArrayis:\n");//输出数组元素
for(i=0;i<N;i++)
printf("%4d",a[i]);
printf("\n");
return;
}
voidinvert(inta[]){
inti,temp;
for(i=0;i<N/2;i++){/*交换数组元素使之逆序*/
temp=a[i];
a[i]=a[N-i-1];
a[N-i-1]=temp;
}
printf("\n");
return;
}
3、(选做)(1)调试程序:在二维数组中,若某一位置上的元素在该行中最大,而在该列中最小,则该元素即为该二维数组的一个鞍点。要求从键盘上输入一个二维数组,当鞍点存在时,把鞍点出来。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。