实验三 C基本数据类型及运算
1. 编程:根据需要定义相关变量,键盘输入10.0、20.6、5.0三个实数分别赋给相关三个变量,输出该3个变量的和s、乘积p和平均值a。
2. 编程:输入球的半径,计算球体表面积和球体积。
3. 编程:定义6个变量,通过键盘将“10, -10, 40000, a, 3.14, hello”这六个值分别赋给相应变量,然后在屏幕上输出变量的值(每行输出一个变量)。
4. 编程:从键盘接收1个字符给变量s1,1个字符串(允许带有空格)给字符数组s2,输出字符变量s1的ASCII码值及字符数组s2中的字符串。
5. 编程:从键盘输入二个整数分别赋给整型变量a、b,将它们按由小到大的顺序输出。 6. 编程:调用标准库函数sin(x)计算6800的正弦值(此题为选做)。
7. 编程:键盘输入一个实数赋给变量x,计算 y=x*x*x+x*x+x 的值,分别输出y值、y值的整数部分和小数部分(此题为选做)。
8. 编程:键盘输入四个整数分别赋给整型变量a、b、c、d,用三目运算方法将它们按由大到小的顺序输出(此题为选做)。 1. #include
{float x,y,z,s,p,a;
scanf(\s=x+y+z; p=x*y*z; a=s/3;
printf(\}
2. #include
3. #include
main()
{int a,b;long c;char d,st[6];float e; scanf(\
printf(\}
4. #include
{ char s1,s2[6]; scanf(\printf(\}
5. #include
scanf(\if (a
printf(\else
printf(\}
6. #include
7. #include
{float x,y,b;int a; scanf(\y=x*x*x+x*x+x; a=(int)y; b=y-a;
printf(\}
实验四 C分支结构程序设计
1. 编程:从键盘输入一个字符,如是大写字母,则输出相应小写字母;如是小写字母,则原样输出;其它字符输出“Not letter!”。
2. 编程:判断输入的正整数是否既是3又是5的整数倍。若是,输出Yes,否则输出No。 3. 编程:从键盘输入三个整数,分别赋给变量a,b,c,输出其中的最大值(要求不改变a、b、c的值)。
4. 编程:用scanf输入任意两个数分别赋给变量a、b,若a大于等于b,则直接输出a、b,否则将a、b的值交换(即a的原值放入b中,b的原值放入a中)后再输出。
5. 编程:输入整数a和b,若a+ b大于100,则输出a+ b百位以上的数字,否则输出两数之和。
6. 编程:从键盘输入三个整数,分别赋给变量a,b,c,请按从小到大的顺序依次输出a、b、c(要求不改变a、b、c的值)。
7. 编程:从键盘输入三个整数,分别赋给变量a,b,c,请按从小到大的顺序依次将这三个数存放于a、b、c中,最后输出a、b、c。
8. 编程:由系统生成一个10以内的随机整数,用户从键盘上输入一个10以内的整数,如果两者相等输出“OK”,否则输出“ERROR”。
注:随机数的生成必须包含头文件#include
scanf(\if(x>='a'&&x<='z') printf(\
else if (x>='A'&&x<='Z') printf(\
else printf(\}
2. #include
scanf(\if (x>0)
{ if(x%3==0&&x%5==0) printf(\
else printf(\else printf(\}
3. #include
{int a,b,c,max;
scanf(\max=a>b?a:b;
2
2
2
2
max=max>c?max:c;
printf(\}
4. #include
{float a,b;
scanf(\if(a
printf(\} 5.
#include
{int a,b,t,r,s;
scanf(\s=a+b;
r=a*a+b*b; t=r/100; if(r>100)
printf(\
else printf(\} 6.
#include
{int a,b,c,d,max,min;
scanf(\if(a>=b) {max=a;
min=b;} else {max=b; min=a;} if(c>=max) max=c;
if(c<=min) min=c;
d=a+b+c-min-max;
printf(\} 7.
#include
{ int a, b, c, d;
scanf(\ if(a>=b) {d = a; a = b; b = d;} else if(b>=c) { d = b; b = c; c = d; }
printf(\}
8.
#include
srand((unsigned)time(NULL)); b=rand()+1; scanf(\
printf(\随机数b=%d\\n\if(a==b)
printf(\
else printf(\}
实验五 C多分支结构程序设计*
1. 编程:计算奖学金ss的值,已知奖学金ss与成绩s的关系为:
具体要求:
(1)用 if 语句实现分支结构的编程。 (2)s为整型,ss要求精确到小数点后二位。 (3)用scanf函数给s赋值,且输入前有相应提示。 (4)结果输出时采用以下形式:
成绩s=具体值,奖学金ss=具体值 2. 设函数f(x)如下,求函数函数法f(x)的值。
具体要求:
(1)用条件表达式编程。 (2)用if语句编程。
(3)用scanf函数给自变量赋值,且输入前有相应提示。 (4)结果输出时采用以下形式: x=具体值,f(x)=具体值 (5)给出你所使用的测试用例。 提示:
按C的语法规则,标识符由字母、数字、下划线组成,不能将f(x)作为变量名,本题中,函数名可起为 f 或 y 等。但作为非格式控制字符,f(x)完全可以出现在printf函数的双引号内。
3. 编程:输入一个整数,判断它能否被3,5,7整除,并输出以下信息之一: (1)能同时被3,5,7整除。
(2)能被其中两数整除(指出是哪两个数)。 (3)能被其中一个数(指出是哪一个数)整除。 (4)不能被3,5,7任一个数整除。
4. 编程:用switch 语句编写一个简单的计算器程序,输入格式为:data1 op data2。其中data1和data2为参加运算的两个数;op为运算符,取值只能是+、-、*、/。 5. 编程:计算你的出生日期是星期几。
(1)通过键盘输入你出生那一年的元旦是星期几 (2)通过键盘输入你的出生日期 (3)输出结果 1.
#include
{int s; float ss;
printf(\scanf(\if(s<0||s>100) printf(\else {if(s>=0&&s<80) ss=0;
else if(s>=80&&s<90) ss=100+s;
else if(s>=90&&s<=100) } } 2.
#include
{float x;int f;
printf(\scanf(\if(x==0) f=0; else f=(x>0)?1:-1;
printf(\} 3.
#include
ss=200+s*3/2;
printf(\成绩s=%d,奖学金ss=%0.2f\\n\
{int x,a,b,c;
printf(\请输入一个整数x\scanf(\a=x%3; b=x%5; c=x%7;
if(a==0&&b==0&&c==0)
printf(\能同时被3,5,7整除\\n\
else if(a==0 && b==0) printf(\能被3,5整除\\n\,x); else if(a==0 && c==0) printf(\能被3,7整除\\n\ } 4.
#include
printf(\请输入算式\scanf(\switch(op)
{case '+': printf(\ case '-': printf(\ case '*': printf(\ case '/': printf(\ } } 5.
#include
int x,m,d;
printf(\请输入你出生那年元旦的星期(1至7):\\n\printf(\请输入你的出生日期 (mm/dd) : \\n\scanf(\switch ((m*30+d)/7)
{case 0:printf(\你出生那天为星期%d\case 1:printf(\你出生那天为星期%d\case 2:printf(\你出生那天为星期%d\case 3:printf(\你出生那天为星期%d\case 4:printf(\你出生那天为星期%d\
else if(b==0 && c==0) printf(\能被5,7整除\\n\
else if(a==0) printf(\能被3整除\\n\
else if(b==0) printf(\能被5整除\\n\
else if(c==0) printf(\能被7整除\\n\,x);
else printf(\不能被3,5,7任意一个数整除\\n\
case 5:printf(\你出生那天为星期%d\case 6:printf(\你出生那天为星期%d\} }
实验六 C循环结构程序设计
1. 编程:输出200以内所有能被7整除的数。
2. 编程:求出1 ~ 1000之间能被13整除的最大的那个数。 3. 编程:找出若干个非零数中的最小值m以及它们的平均值a。
要求:若干个数由键盘输入,每次输入一个赋给变量x,x为零时,结束输入。 4. 编程:求两个正整数m、n之间所有奇数之和x与偶数之和y。 要求:
(1)m、n的值由键盘输入。
(2)输入时,允许用户随意先输入大的或小的整数。
5. 编程:计算函数y的值。要求键盘接收自变量x的值,若x的值不为零,计算函数y的值并输出,再从键盘接收下一个x的值,……,直到x的值为零,显示“Thank You,Bye!”,尔后结束程序,已知函数y与自变量x的关系为:
6. 编程:计算π的近似值,π的计算公式为:
要求:
(1)n值由键盘输入。
(2)分别输出当n 为10、100、1000时的计算结果。 (3)输出时要求每行显示一组n、π的值,每行形式如下: n=具体值,π = 具体值
7. 我国现有人口13亿,设年增长率为1%,编写程序,计算多少年后增加到20亿。
8. 求解爱因斯坦数学题。有一条长阶梯,若每步跨2阶,则最后剩余1阶;若每步跨3阶,则最后剩2阶;若每步跨5阶,则最后剩4阶;若每步跨6阶,则最后剩5阶;若每步跨7阶,最后才正好一阶不剩。请问,这条阶梯最少共有多少阶?
9. 每个苹果0.8 元,第一天买2 个苹果,第二天开始,每天买前一天的2 倍,直至购买的苹果个数达到不超过100 的最大值。编程:求每天平均花多少钱?(此题为选做) 1.
#include
for(i=1;i<=200;i++) {if(i%7!=0) continue; printf(\} } 2.
#include printf(\} 3. #include {int i;float x,m,s,a; scanf(\if(x!=0) {m=x;s=x;} for(i=1;;i++) {scanf(\if(x==0) break; s=s+x; if(m>x) m=x; } a=s/i; printf(\最小值m=%f,平均值a=%f\} 4. #include void main() {int i,m,n,t,x=0,y=0; scanf(\if(m>n){t=m;m=n;n=t;} for(i=m;i<=n;i++) if(i%2) x+=i; else y+=i; printf(\printf(\} 5. #include float x,y; printf(\scanf(\for (;x>=0;) { if(x>0&&x<100) { y=3*x+1; printf(\} else if(x>=100) { y=x*x-1; printf(\} else {printf(\scanf(\} } 6. #include printf(\请输入n的值\\n\ scanf(\ sum=2; i=1; t=2; while(i t=t*(2*i)*(2*i)/(2*i-1)/(2*i+1); i=i+1; } printf(\\\n\} 7. #include double t=13,s=0; while(t<=20) { t=t*(1+0.01); s++; } printf(\需要经过%lf 年\} 8. #include while( !(x%2==1&&x%3==2&&x%5==4&&x%6==5)) { x=x+7; } printf(\} 9. #include { d++; n=n*2; p=p+n; } while(p+n*2<=100); s=p*0.8/d; printf(\每天平均花%g元钱!\\n\} 实验七 C多重循环结构程序设计 1. 编程:输出100以内个位数为6且能被3整除的所有数。 2. 编程:键盘输入6 位学生的5门课成绩,分别统计出每个学生的平均成绩。 3. 编程:输入一个正整数,统计该数的各位数字中零的个数,并求各位数字中的最大者。 4. 编程:分别用do while、while、for三种循环结构求: 1!+2!+3!+...+n! ,要求n的值由键盘输入。 5. 编程:计算100至1000之间有多少个数其各位数字之和是5。 6. 编程:从键盘输入的10个整数中,找出第一个能被7整除的数。若找到,输出此数后退出;若未找到,输出“not exist”。 7. 编程:输出1至100之间满足如下条件的数:各位数的乘积大于各位数的和。 8. 编程:将整数316表示为两个加数的和,使这两个加数分别能被13和11整除。 9. 编程:打印出所有的\水仙花数\。所谓的\水仙花数\是指一个3位数,其各位数字的立方和等于该数本身。例如,153是一个\水仙花数\,因为有153=1*1*1+5*5*5+3*3*3。 10. 编程:一条有10个车站的铁路线,共需要准备多少种车票? 1. #include for(i=1;i<=100;i++) {if(i==6&&i%3==0) printf(\} } 2. #include {int i,j,a[6][5];float s; for(i=0;i<6;i++) {s=0; for(j=0;j<5;j++) {printf(\请输入第%d个学生的第%d门成绩\scanf(\s=s+a[i][j]; } s=s/5; printf(\第%d个学生平均成绩为%f\\n\} } 3. #include {int x,i,max,t; i=0; max=0; scanf(\do {t=x; if(t==0) ++i; else if(max printf(\} 4. #include {int n,i,a,s=0; printf(\请输入n:\scanf(\a=1; for(i=1;i<=n;i++) {a=a*i; s=s+a; } printf(\} #include {int n,i=1,a=1,s=0; printf(\请输入n:\scanf(\while(i<=n) {a=a*i; s=s+a; i++; } print(\} #include {int n,i=1,a=1,s=0; printf(\请输入n:\scanf(\do {a=a*i; s=s+a; i++; } while(i<=n); printf(\} 5. void main() { int i,s,k,count=0; for(i=100;i<1000;i++) { s=0; k=i; while(k) { s=s+k; k=k/10; } if(s!=5) continue; else count++; } printf(\} 6. #include printf(\请输入10个整数:\for(i=1;i<=10;i++) {scanf(\if(x%7==0) {printf(\} } if(i>10) printf(\} 7. #include {int n,k=1,s=0,m ; for (n=1;n<=100;n++) {k=1;s=0;m=n; while (m>=1) {k*=m; s+=m; m=m/10 ; } if(k>s) } } 8. #include printf(\} 9. #include {int i,j,k,n; for(n=100;n<1000;n++) { i=n/100; j=(n-i*100)/10; k=n; if(i*i*i+j*j*j+k*k*k==n) printf(\ printf(\ } } 实验八 C程序控制结构综合应用 1. 编程计算: s=1+12+123+1234+12345+123456+1234567。 2. 编程: 找出1至99之间的全部同构数。所谓同构数是这样一组数:它出现在其平方数的右边。例如:5是25右边的数,25是625右边的数,5和25都是同构数。 3. 若用0至9之间不同的三个数构成一个三位数,编程统计共有多少种方法。 4. 编程:键盘输入一个不多于5位的正整数,要求:(此题为选做) (1) 求它是几位数 (2) 逆序打印出各位数字。如原数为123,输出则为321。 5. 编程:找出以下疑案的作案人(此题为选做) 已知该案涉及6个嫌疑人A、B、C、D、E、F,并且: (1) A、B至少有一人作案。 (2) A、E、F这3人中至少有2人参与作案。 (3) A、D不可能是同案犯。 (4) B、C或同时作案,或与本案无关。 (5) C、D中有且仅有一人作案。 (6) 如果D没有作案,则E也不可能参与作案。 6. 编程:输出下列形式的杨辉三角形的前10行(此题为选做) 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 …… 1. #include {int s=0,i=1,t=0; while(i<10) {t=t*10+i;s+=t;i++; } printf(\} 2. #include main() {int i; for(i=1;i<=99;i++) if(i*i==i||i*i0==i) printf(\} 3. #include {int i,j,k,count=0; } for(i=1;i<=9;i++) for(j=0;j<=9;j++) if(i==j) continue; else for(k=0;k<=9;k++) if(k!=i&&k!=j) count++; printf(\ 实验九 C的数组 1. 编程实现:输入一个正整数n(1 例如:输入5,再输入三个数8、23、1、7、19,则输出为:19、7、1、23、8。 2. 编程实现:输入10个正整数,将它们中的最小值与第一个数交换,最大值与最后一个数交换,然后输出交换后的10个数。 3. 编程实现:已知二次等差数列的前4项为2,5,10,17,请定义一维整型数组存储该数列的前20项,并每5个数为一行输出该数列的前20项。 4. 已知一组整型数据已按从小到大排列好,现任意输入一个整数,请按原来排序的规律将它插入到数组中(例如:原来的一组整数为1,3,5,8,9,若输入的整数是7,则最终的结果为: 1,3,5,7,8,9),请编程实现。 5. 编程:将一个4×4的整型矩阵元素按副对角线(右上到左下)互换。 要求: (1)键盘输入矩阵各元素的值。 (2)互换前,按矩阵形式输出矩阵。 (3)互换后,按矩阵形式输出矩阵。 6. 求一个4×4的整数矩阵的副对角线(右上到左下)上所有奇数的和sum及偶数的平均值ave。 要求:结果保留2位小数 7. 通过循环按行顺序为一个5×5的二维数组a赋1到25的自然数,然后输出该数组的左下半角元素的值和它们之和。 8. 定义一个实数型数组,将10个实数输入到数组中,编程实现任一块区间所有元素的平均值,即输入两整数m,n,计算出数组中第m个元素开始的后n个元素的平均值,包括第m个元素(若n值过大,即个数太多,超过数组的最后一个元素,则统计到最后一个元素)。 例如:数组元素为1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0,输入3,5,则输出5.0。 9. 一个整型数组有10个元素,编写程序删除所有值为n的元素。如:数组中为1,3,2,4,2,7,9,0,2,5,n的值为2,删除后输出数组元素应该为1,3,4,7,9,0,5。(此题为选做) 10. 定义两个N行N列的二维数组a、b,编写程序,将a数组最后一行放到b数组的第0列中,把a数组中的第0行放到b数组的最后一列中,b所指二维数组中其他元素的数据不变。(此题为选做) 11. 试编程实现如下功能:先定义一个4行5列的数组(矩阵),调用库函数rand()随机产生20-50之间的整数给数组元素赋值,再将矩阵中第二列与第四列的元素互换。要求先输出原数组,再输出交换后的数组(rand函数的使用请参阅教材259页)。(此题为选做) 1. #include int a[10],n,i; scanf(\ for(i=n-1;i>=0;i--)scanf(\for(i=0;i #include int n,i,a[10],max,min,t,r,p; scanf(\for (i=1;i<=n;i++) scanf(\min=a[1]; for (i=1;i<=n;i++) { if (a[i] } } t=a[1],a[1]=min,a[r]=t; max=a[n]; for (i=1;i<=n;i++) { if (a[i]>a[n]) { max=a[i]; p=i; } } t=a[n],a[n]=max,a[p]=t; for (i=1;i<=n;i++) printf(\} 3. #include printf(\ if(i%5==0) } } 4. #include {int a[10]={1,3,5,7,9,11,13,15,17},i,j,n; printf(\请输入1个整数\scanf(\for(i=0;i<9;i++) if(a[i]>n) {for(j=9;j>i;j--)a[j]=a[j-1]; a[i]=n; break; } if(n>=a[8])a[9]=n; for(i=0;i<10;i++) printf(\printf(\} printf(\ 6. #include {int a[4][4],i,j,t=0; float s1=0 ,s2=0,ave; for(i=0;i<=3;i++) { for(j=0;j<=3;j++) {printf(\scanf(\} } for(i=0;i<=3;i++) { for(j=3;j>=0;j--) { if(i+j==3) {if(a[i][j]%2!=0) {s1=s1+a[i][j]; } else { t++; s2=s2+a[i][j]; ave=s2/t; } } } } printf(\} 7. #include int i,j,k=1,s=0; int a[5][5]; for(i=0;i<5;i++) { for(j=0;j<5;j++) { a[i][j]=k; k++; } } putchar(10); for(i=0;i<5;i++) { for(j=0;j<5;j++) printf(\ printf(\ } putchar(10); for(i=0;i<5;i++) { for(j=0;j<=i;j++) printf(\ printf(\ s=s+a[i][j]; } printf(\} 实验十 C字符数组和字符串函数* 1. 编写字符串拷贝程序,并要求拷贝过程中将字符串中的小写字母转换成大写字母。 2. 从键盘输入两个字符串a和b,要求不使用库函数strcat,把串b的前5个字符连接到串a中;如果b中的长度小于5,则把b的所有元素都连接到a中。 3. 输入一个以回车结束的字符串(少于80个字符),再输入一个字符,统计并输出该字符在字符串中出现的次数,然后输出该字符串。 4. 编程: 输入一个字符串,输出该字符串中出现次数最多的字符以及出现的次数。 5. 编程: 键盘接收一个字符串(只含大、小写英文字母),将该字符串加密后输出。 加密规则为:若为小写字母则不变,若为大写字母则将其转换为小写后再后移一个字母,例如“A”应转换为“b”,“B”应转换为“c”,“Y”应转换为“z”,而“Z”应转换为“a”。 6. 编程:输入一个以回车结束的字符串a(少于80个字符),再输入一个字符串b,统计并输出b在a中出现的次数,然后再输出这两个字符串。 7. 编程:输入一个以回车结束的字符串(少于80个字符),将该字符串倒序存放后按顺序输出。 例如:如数组中开始时元素为“abcd”,程序执行后数组中为“dcba”,并输出“dcba” 8. 编程: 实现对字符串的加密,要求从键盘输入一个字符串,输出加密之后的字符串。(此题为选做) 加密规则为: 对于串中第奇数个字符,若是字母,则把该字母变为它后面的字母(若为Z则变为A),不是字母则不变; 对于串中第偶数个字符,若是字母,则把该字母变为它前面的字母(若为A则变为Z),不是字母则不变; 大小写字母都遵循此规则。 例如: 若原字符串是:AbbaZG Ha-MnnK Yzx 加密字符串为:BaczAF Gb-Nmoj Xaw 9. 编程:输入一行英文字符串,统计单词的个数(单词和单词以空格分隔)。做) 1. #include char str1[40],str2[20]; int i,k; printf(\请输入第一个字符串\\n\scanf(\ printf(\请输入第二个字符串\\n\scanf(\ for(i=0;str1[i]!='\\0';i++); for(k=0;str2[k]!='\\0';k++) { str1[i]=str2[k]; i++; } str1[i]='\\0'; for(i=0;str1[i]!='\\0';i++) { if(str1[i]>='a' && str1[i]<='z') { str1[i]=str1[i]-32; } } printf(\} 2. #include \main() {char a[80],b[40],*q=a,*p=b;int i=0; printf(\字符串a:\gets(a); (此题为选 printf(\字符串b:\gets(b); while(*q++); q--; while(*p++) i++; p=b; if(i<5) while(i--) *q++=*p++; else for(i=0;i<5;i++) *q++=b[i]; *q='\\0'; puts(a); } 3. #include {char c[80],ch; int i,num=0; printf(\请输入字符串及字符:\gets(c); ch=getchar(); for(i=0;c[i]!='\\0';i++) if(c[i]==ch) num++; printf(\puts(c); } 4. #include { char str[100],str_sort[100],c; int i,j,len,m; printf(\请输入字符串:\ gets(str); strcpy(str_sort,str); len=strlen(str_sort); for(i=0;i str_sort[j]=str_sort[j+1]; str_sort[j+1]=c; } for(i=1,j=1,m=0;i { if(j>m) { m=j; c=str_sort[i-1]; } j=1; } else j++; printf(\出现最多的是:%c %d\\n\ getch(); } 5. #include #include {char c[80],ch; int i,l; gets(c); l=strlen(c); for(i=0;i char i; int c=0; int a=0,sum; scanf(\while(i!='\\n') { } printf(\} if(i=='Z')i=i+32-25,printf(\scanf(\ { if('a'<=i&&i<='z')printf(\if('A'<=i&&i<='Y')i=i+33,printf(\ 实验十一 C排序算法* 1. 编程实现:输入n(n<10)个整数,按从大到小的顺序对其排序并输出。 2. 编程实现:输入一个字符串,按字符从小到大的顺序对其排序输出。 3. 编程实现:键盘输入同寝室n位同学的姓名(用汉语拼音表示),将这n位同学的姓名按字母顺序排序后输出。(此题为选做) 1. #include printf(\请输入这%d个数:\ for( i=0;i for(i=0;i for(i=0;i #include char str1[500]={0},str2[256]={0}; printf(\ printf(\ for( j=0;j if(a[j]1&&n<=10)c=0; else printf(\ } int i;gets(str1); for(i=0;str1[i];i++) { str2[str1[i]]=1; } for(i=0;i!=256;i++) if(str2[i]==1) printf(\putchar('\\n'); return 0; } 实验十二 C函数的基本操作 1. 编写函数:计算三角形的面积。已知三角形三条边长,公式为: 其中x、y、z为边长,c=(x+y+z)/2。 2. 编写函数:用来判断一个整数是否满足“用4除余1,用5除余3,用7除余4”,满足则返回1,不满足返回0,然后编写main函数,通过调用该函数显示出200~500之间满足该条件的数。 3. 编写函数isprime( ),用来判断一个整数a是否为素数。再编写main函数,通过调用该函数打印出100~300之间所有的素数,要求一行打印10个。 4. 编写函数:判断一个整数是否为水仙花数,并编写主程序调用该函数求出所有的水仙花数。 5. 用迭代法求。迭代公式为: 迭代到为止 ,为方程的近似解。 6. 所谓完数就是它所有因子的和等于其自身自然数,如6=1+2+3,6就是一个完数。编写两个函数:函数factor(n)用来判断n是否是完数,函数PriFac(n)用来显示完数n的所有因子,在主函数中调用这两个函数,显示1~30000间的所有完数。 7. 以下函数p的功能是用递归方法计算x的n阶勒让德多项式的值。已有调用语句p(n,x);请编写p函数。递归公式如下:(此题为选做) float p(int n, int x) { } 1. #include { double a, b, c, p, s; printf(\请输入a, b和c:\ scanf(\ p = (a + b + c) / 2; s = sqrt(p * (p - a) * (p - b) * (p -c)); printf(\此三角形的面积为:%lf\\n\ return 0; } 2. #include while(m<=n) { if(m%4==1&&m%5==3&&m%7==4) {printf(\m++; } } void main() { fun(200,500); } 3. #include for(y=x-1;y>=1;y--) { if(x%y==0) {return y; break;} } } main() {int i,j=0,m; for(i=100;i<=300;i++) {m=isprime(i); if(m==1) {printf(\j++; if(j==0) printf(\} } } 4. #include for(x=100;x<1000;x++) { a=(x/100); b=(x/10); c=x; if( x==a*a*a+b*b*b+c*c*c) printf(\ } } main() {int y; fun(y); } 5. #include { double a, b, c, d, e; printf(\ scanf(\ e = pow(a, 1.0/3); do { c = b * 2/3 + a / (3 * b * b); d = c - b; b = c; } while((d <= -0.00001) || (d >= 0.00001)); printf(\6. #include void prifac(int n); int w[10],k; main() { int m,n; for(n=2;n<=3000;n++) } int factor(int n) {int s,i; k=-1; s=n; for(i=1;i void prifac(int n) {int i; printf(\是完数\\n\} {m=factor(n); if(m==1)prifac(n); } 实验十三 C函数调用中的数据传递 1. 编程实现:在主程序main( )中输入2个整数,通过调用函数将两者的值互换(要求分别用地址传递方式、全局外部变量传递方式编程)。 2. 编写函数:功能是删除字符串s中的所有数字字符。 3. 编写函数:功能是返回字符串s中的指定字符c的出现次数。 4. 在main函数中,定义一个含N个元素的数组,其中N是符号常量,然后编写下列各子函数完成相应的功能: (1)编写函数sr:为该数组各元素赋值(要求调用随机函数为各数组元素赋值)。 (2)编写函数sc:打印该数组各元素,要求每行打印m个数,其中m作为形参传递。 (3)编写函数js:求该数组元素的最大值和最小值,最大值和最小值通过参数传递返回主调函数。 (4)编写函数px:实现对数组的排序。 各个函数编写完成后,请编写main函数,并在main中分别调用以上四个函数,以验证各子函数的功能。 1. #include printf(\scanf(\swap(&a,&b); printf(\交换后:a=%d,b=%d\\n\} void swap(int *p1,int *p2) { int t; t=*p1,*p1=*p2,*p2=t; } 2. #include printf(\scanf( \Swap(x,y); printf(\} void Swap() { int temp; temp=x; x=y; y=temp; return; } 3. #include void fun(char c[80], char x[1]) {int i = 0; int bit = 0; for(i = 0; c[i]; i++) { if(c[i] !=x[0] ) { c[bit] = c[i]; bit++; } } c[bit]='\\0'; } void main() {char c[80];char a[1]; printf(\请输入一串字符:\scanf(\ printf(\请输入要删除的数:\scanf(\fun(c,a); printf(\} 实验十五 C的指针 1. 用指针方法,编写一个函数,求矩阵主对角线所有偶数元素之和Sum。 2. 编程:用字符指针实现函数strcat(s,t),将字符串t复制到字符串s的未端,并且返回字符串s的首地址。 3. 用指针编程:输入一个字符串,计算该字符串的长度,并统计该串中所含小写字母、大写字母和其他字符的个数。 4. 用指针编程: 将字符串a赋给一个字符数组,然后从第一个字母开始间隔地输出该串。例如,输入的是abcdefghijkl,则输出为acegik。 5. 用指针编程:有一个数列,含有20个整数,编写函数,要求能够对从指定位置开始的n个数按相反顺序重新排列,并在main中输出新的数列。 例如,原数列为: 1,2,3,4,5,6,7,8,9,10 若要求对从3个数开始的5个数进行逆序处理,则处理后的新数列为: 1,2,7,6,5,4,3,8,9,10 6. 用指针编程:输入一个4×5的二维整型数组,输出其中最大值、最小值以及它们所在行和列的下标。 7. 用指针编程:从键盘输入15个整数存入一维数组,按逆序存放后再输出。 1. #include main() {int a[4][4]={1,2,3,4,2,3,4,5,3,4,6,6,4,5,6,8},*p[4],i,j,sum=0; for(i=0;i<4;i++) p[i]=&a[i]; for(i=0;i<4;i++) {if (*(p[i]+i)%2==0) sum+=*(p[i]+i); } printf(\} 2. #include #include {char a[100],*p=a; int x=0,y=0,z=0,n=0; gets(a); while(*p!='\\0') { } 4. #include if(*p>='a'&&*p<='z') x++; y++; z++; else if(*p>='A'&&*p<='Z') else p++; n++;} printf(\小写=%d,大写=%d,其他=%d,长度=%d\\n\ #include {char a[100],b[100],*p=a,*q=b; int i=0; gets(a); i=strlen(a); while(p #include void invert(int *A, int pos, int n) { int i; int *p,t; p=A+pos; for(i=0;i *(p+i)=*(p+n-1-i); } void main() { int i,x,y; int a[20]; printf(\请输入20个数:\\n\for(i=0;i<20;i++) { } printf(\从第x个数开始,对后面的y个数进行从小到大排序,输入x、y:\\n\scanf(\printf(\原始数列是:\\n\for(i=0;i<20;i++) { } invert(a,x,y); printf(\排序后的数列为:\\n\for(i=0;i<20;i++) { } } printf(\printf(\ scanf(\ *(p+n-1-i)=t; } 6. #include {int i,j,a[4][5],*p=*a,min,max,e,b,c,d; for(i=0;i<4;i++) } } } 7. #include {int a[15],*p[15],t,i; for(i=0;i<15;i++) scanf(\ for (i=0;i<15;i++) p[i]=&a[i]; for (i=0;i<15/2;i++) {t=*p[i];*p[i]=*p[14-i];*p[14-i]=t;} for(i=0;i<15;i++) printf(\} printf(\最大值为:%d,行标:%d,列标:%d\\n\ printf(\最小值为:%d,行标:%d,列标:%d\\n\ p++; if(min>*p) { min=*p; b=j; for(j=0;j<5;j++) {scanf(\ if(i==0&&j==0) {max=*p; min=*p; e=0; b=0; c=0; d=0; if(max<*p) { max=*p; c=i; d=j; } e=i; }