交大程序设计C试验三程序_第1页
交大程序设计C试验三程序_第2页
交大程序设计C试验三程序_第3页
交大程序设计C试验三程序_第4页
交大程序设计C试验三程序_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、程序填空给定程序中函数fun的功能是:找出100〜n(不大于1000)之间的三位数字相等的所有整数,把这些整数放在s所指的数组中,整数的个数作为函数值返回。在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果即可。程序填空如下:修改后代码如下:#include<stdio.h>#defineN100intfun(int*s,intn){inti,j,k,a,b,c;j=0;for(i=100;i<n;i++){found**************/found**************//**************k=i;found**************/found**************/a=k%10;k/=10;b=k%10;k/=10;/**************c=k;if(a==b&&a==c)s[j++]=i;}returnj;}main(){inta[N],n,num=0,i;do{printf("\nEntern(<=1000); ");scanf("%d",&n);}while(n>1000);num=fun(a,n);printf("\n\nTheresult:\n");for(i=0;i<num;i++)printf("%5d",a[i]);printf("\n\n");}2、程序改错给定程序中函数fun的功能是:将形参n中各位上为偶数的数取出,并按原来从高位到低位的顺序组成一个新的数,并作为函数值返回。例如,从主函数输入一个整数27638496,函数返回值为26846。请改正函数fun中指定部位的错误,使它能够得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。需改正程序如下:修改后代码如下:#include<stdio.h>longfun(longn){longx=0,s,i;intt;s=n;/*********found**********/i=1;/*********found**********/while(s>0){t=s%10;if(t%2==0){/*********found**********/x=x+t*i;i=i*10;}s=s/10;}returnx;}main(){longn=-1;while(n>9999999911n<0){printf("Pleaseinput(0<n<100000000):");scanf("%ld",&n);}printf("\nTheresultis:%ld\n",fun(n));}3、编程题(1)给定程序中函数fun的功能是:输出M行M列的整数方阵,然后求两条对角线上的元素之和,要求返回此和数。同时,在函数中需完整输出整数方阵和对角线上元素之和。因此,编写程序时需注意方阵元素的排列顺序和求对角线元素之和时不要漏项。注意:切勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入编写的语句。程序如下:#include<conio.h>#include<stdio.h>#defineM5intfun(intn,intxx[M][M])(}main(){intaa[M][M]={{1,2,3,4,5},{4,3,2,1,0},{6,7,8,9,0},{9,8,7,6,5},{3,4,5,6,7}};printf(“\nThesumofallelementson2diagnalsis%d.“,fun(M,aa));}编程后代码如下:#include<conio.h>#include<stdio.h>#defineM5intfun(intn,intxx[M][M]){inti,j,sum=0;printf("整数方阵为:\n");for(i=0;i<n;i++){for(j=0;j<n;j++){printf("%3d”,xx[i][j]);}printf("\n");}printf("\n相加的数组元素为:\n");for(i=0;i<n;i++){for(j=0;j<n;j++){if(i==j){printf("xx[%d][%d]=%d\n",i,j,xx[i][j]);sum+=xx[i][j];}if(j==(n-1)-i){printf("xx[%d][%d]=%d\n",i,j,xx[i][j]);sum+=xx[i][j];}}}returnsum;}main(){intaa[M][M]={{1,2,3,4,5},{4,3,2,1,0},{6,7,8,9,0},{9,8,7,6,5},{3,4,5,6,7}};printf("\nThesumofallelementson2diagnalsis%d.",fun(M,aa));}(2)使用递归方法求解斐波那契数列的前30项。其中,斐波那契数列由以下公式定义:0 (n=0)Fib(n)=1 (n=1)Fib(n-2)+Fib(n-1) (n>1)从上述公式可以看出:斐波那契数列的第1个数是0,第2个数是1,从第3个数开始,以后每个数都是前两个数之和。编程后代码如下:#include<conio.h>#include<stdio.h>intfib(intn){if(n==0){return0;}elseif(n==1){return1;}else{returnfib(n-2)+fib(n-1);}}intmain(void){inti,a;printf("斐波那契数列的前30项为:\n");for(i=0;i<30;i++){a=fib(i);printf("f(%2d)=%d\n",i,a);}}选做题:【编程扩展题】开放式基金是一种委托投资理财产品。用户可以向基金管理机构购买/赎回基金,基金管理机构负责将基金投资于股票等金融产品获取收益,并收取一定的管理费用。假设某基金在成立时每份面值为1元,申购费率为1.5%,赎回费率为0.5%。则有如下规则:每个用户购买时的金额必须大于等于1000,并且是1000的整数倍;基金份额=购买金额*(1—申购费率)/份额面值;基金运作后每天公布当日每份基金净值,如0.9871或者1.0121,则:用户当前净值=基金份额X当日每份基金净值;每日净值增长率=(当日每份基金净值一昨日每份基金净值)/昨日每份基金净值X100%;浮动盈亏=用户当前净值X(1一赎回费率)一购买金额;周平均净值=一周每日净值的和/工作日;;编写一个程序,要求用户输入在基金成立时的购买金额和基金运作第一周的每日每份基金净值,统计一周来用户的收益情况(提示:可用数组存放一周中每日的数据)。例如,一次程序运行的情况如下:Pleaseinputyourmoney(>1000,andmultiple):15001500isnotmultipleof1000.Pleaseinputyourmoney(>=1000,andmultiple):10000Pleaseinputeverydaynetvalueinthisweek:0.98720.99351.01020.99051.0235QuotientNetValueIncreaseRateCurrentValueCurrentPayoff98500.98720.00%9724 -32598500.99350.64%9786 -26398501.01021.68%9950 -9998500.9905-1.95% 9756-29298501.02353.33%10081 31AverageNetValueinthisweek=1.00098编程后代码如下:#include<stdio.h>#defineM5//工作日天数intmain(void){inti,input;//购买金额charheader[M][16]={"Quotient","NetValue","IncreaseRate","CurrentValue","CurrentPayoff"};floatfacevalue=1.0;//面值floatexprate=0.015;//申购费率floatredrate=0.005;//赎回汇率floatquotient;//份额floatsumnetvalue=0;//周净值和floatweekavg;//周平均净值//定义个数组分别存一周内每个工作日的净值,增长率,用户当前净值,当前浮动盈亏floatnetvalue[M];//净值floatincrate[M];//每日净值增长率floatcurvalue[M];//用户当前净值floatcurpayoff[M];//浮动盈亏//输入的倍数printf("Pleaseinputyourmoney(>1000,andmultiple):");scanf_s("%d”,&input);do{if(input==0||input%1000!=0){//判断输入的数是不是的倍数,如果不是继续输入,直到输入正确printf("%disnotmultipleof1000.\n",input);printf("Pleaseinputyourmoney(>=,andmultiple):");scanf_s("%d”,&input);}}while(input==0||input%1000!=0);//计算基金份额:基金份额=购买金额X(-申购费率)/份额面值quotient=input*(1-exprate)/facevalue;//输入净值放入数组中printf("Pleaseinputeverydaynetvalueinthisweek:\n");for(i=0;i<M;i++){scanf_s("%f”,&netvalue[i]);sumnetvalue+=netvalue[i];//计算每日净值增长率:每日净值增长率=(当日每份基金净值-昨日每份基金净值)/昨日每份基金净值X%if(i==0){incrate[i]=0.00;//工作日第一天无法计算前一天净值,所以为}else{incrate[i]=(netvalue[i]-netvalue[i-1])/netvalue[i-1]*100;}//计算用户当前净值:用户当前净值=基金份额X当日每份基金净值curvalue[i]=quotient*netvalue[i];//计算浮动盈亏:浮动盈亏=用户当前净值X(-赎回费率)-购买金额curpayoff[i]=curvalue[i]*(1-redrate)-input;}//计算周平均净值:周平均净值=一周每日净值的和/工作日weekavg=sumnetvalue/M;//打印所有数据printf("\n");for(i=0;i<M;i++){printf("%-16s",header[i]);}printf("\n");for(i=0;i<M;i++){printf("%8.0f

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论