第三部分 编程题
1.m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人数作为函数值返回,将低于平均分的分数放在below所指的数组中。
例如,当score数组中的数据为10、20、30、40、50、60、70、80、90时,函数返回的人数应该是4,below中的数据应为10、20、30、40。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <string.h>
#include <conio.h>
#include <stdio.h>
/*第一个for()循环用来计算score数组中分数的总和,然后用aver/=m求出平均值,第二个循环用来找出小于平均分的元素,并放到数组below中,这里要注意j的递增方式。*/
int fun(int score[],int m, int below[])
{ int i,j=0,aver=0;
for(i=0;i<m;i )
aver =score[i];
aver/=m;
for(i=0;i<m;i )
if(score[i]<aver)
below[j ]=score[i];
return j;
}
main()
{ int i,n,below[9];
int score[9]={10,20,30,40,50,60,70,80,90};
clrscr();
n=fun(score,9,below);
printf("\nBelow the average score are :");
for(i=0;i<n;i ) printf("%4d",below[i]);
}
2.请编写函数fun,它的功能是:求出1到1000之内能被7或11整除、但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <conio.h>
#include <stdio.h>
/*该题关键就是如何表示能被7或11整除,但不能同时被7和11整除。用(i%7==0)//(i%11==0)来表示能被7或11整除,用 !((i%7==0)&&(i%11==0))来表示不能同时被7和11整除。
void fun(int *a,int *n)
{ int i,m=0;
for(i=1;i<1000;i )
if(((i%7==0)//(i%11==0))&&!((i%7==0)&&(i%11==0)))
{a[m]=i;m =1;}
*n=m;
}
main()
{ int aa[1000],n,k;
clrscr();
fun(aa,&n);
for(k=0;k<n;k )
if((k 1)%10==0) printf("\n");
else printf("%d,",aa[k]);
}
3.请编写函数void fun(int x,int pp[ ],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。例如,若x中的值为30,则有4个数符合要求,它们是1,3,5,15。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <conio.h>
#include <stdio.h>
/*由于要求的数不能是偶数故编程时从1开始循环而步长为2这样正好保正i永远的奇数。这里也要注意存放结果的数组pp的下标变化方式。*/
void fun(int x, int pp[], int *n)
{ int i,j=0;
for( i=1;i<=x; i=i 2)
if( x%i==0)
pp[j ]=i;
*n=j;
}
main()
{ int x, aa[1000], n, i;
printf("\n please enter an integer number:\n"); scanf("%d
",&x);
fun(x,aa,&n);
for(i=0;i<n;i )
printf("%d ", aa[i]);
printf("\n");
}
4.请编写一个函数void fun(char *tt,int pp[]),统计在字符串中‘a’到‘z’26个字母各自出现的次数,并依次放在pp所指数组中。
例如,当输入字符串abcdefgabcdeabc后,程序的输出结果应该是:3 3 3 2 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include<conio.h>
#include<stdio.h>
/* 34题:本题采用的是字母的ASCII码值与数组pp下标的对应转换关系分别求出对应字母的个数。第一个for()是给pp赋初值0,第二个for()用于控制在字符串内从头到尾移动。由于字母'a'的ASCII码值为97而它的个数要放在pp[0]中,而'a'-97的值正好为0,其它的依此类推。*/
void fun(char *tt,int pp[])
{ int i;
for(i=0;i<26;i )
pp[i]=0;
for(;*tt;tt )
if(*tt<='z'&&*tt>='a')
pp[*tt-97] ;
}
main()
{ char aa[1000];
int bb[26],k;
clrscr();
printf("\nPlease enter a char string:");scanf("%s",aa)
;
fun(aa,bb);
for(k=0;k<26;k ) printf("%d",bb[k]);
printf("\n");
}
5.请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m 的k个素数存入xx所指的数组中。
例如,若输入:17,5,则应输出:19,23,29,31,37。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <conio.h>
#include <stdio.h>
/*本题中的for()循环用来判断一个数是否为素数,由于个数只能是k个所以用do-while循环来控制。*/
void fun(int m, int k, int xx[])
{ int i,j=0,p=m 1;
do
{for( i=2; i<p; i )
if(p%i==0) break;
if(i>=p) xx[j ]=p;
p ;
} while(j<k);
}
main()
{ int m,n,zz[1000];
printf("\n please enter two integers: ");
scanf("%d%d",&m,&n);
fun( m,n,zz);
for(m=0; m<n; m )
printf("%d ", zz[m]);
printf("\n");
}
6.请编写一个函数void fun(char a[],char b[],int n),其功能是:删除一个字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。
例如,输入一个字符串World,然后输入3,则调用该函数后的结果为Word。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <stdio.h>
#include <conio.h>
#define LEN 20
void fun (char a[ ], char b [ ], int n)
{
int i,k=0;
for(i=0;a[i]!='\0';i )
if(i!=n)
b[k ]=a[i];
b[k]='\0';
}
main( )
{
FILE *wf;
char strl[LEN], str2[LEN];
int n ;
printf ("Enter the string : \n") ;
gets (strl) ;
printf ("Enter the position of the string deleted: ") ;
scanf ("%d", &n) ;
fun (strl, str2, n) ;
printf ("The new string is : %s \n", str2) ;
wf=fopen("out.dat","w");
fun("world",str2,3);
fprintf(wf,"%s",str2);
fclose(wf);
}
7.请编写一个函数int fun(int *s,int t,int *k),用来求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。
例如,输入如下整数:876 675 896 101 301 401 980 431 451 777则输出结果为:6,980。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include<conio.h>
#include <stdio.h>
int fun(int *s,int t,int *k)
{ int i , max ;
max=s[0];
for ( i=0; i<t; i )
if(s[i]>max)
{ max=s[i];
*k=i; }
}
main()
{int a[10]={876,675,896,101,301,401,980,431,451,777},k;
clrscr() ;
fun(a,10,&k);
printf("%d,%d\n",k,a[k]);
}
8.编写函数fun,函数的功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。
s=1 1/(1 2) 1/(1 2 3) ....... 1/(1 2 3 4 ...... n) 例如:若n的值为11时,函数的值为1.833333。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <stdio.h>
float fun(int n)
{ int i,s;
s=0;
for(i=0,i<=n,i ){
s=s 1/chsdc(i);
}
return(s);
}
long chsdc(int n)
{ int i,s;
s=0;
for(i=0,i<n,i ){
s=s i;
}
return(s);
}
main()
{ int n; float s;
printf("\nPlease enter N:"); scanf("%d", &n);
s = fun(n);
printf("the result is: %f\n", s);
NONO();
}
NONO ( )
{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */
FILE *fp, *wf ;
int i, n ;
float s;
fp = fopen("K:\\k1\\24000322\\in.dat","r") ;
wf = fopen("K:\\k1\\24000322\\out.dat","w") ;
for(i = 0 ; i < 10 ; i ) {
fscanf(fp, "%d", &n) ;
s = fun(n) ;
fprintf(wf, "%f\n", s) ;
}
fclose(fp) ;
fclose(wf) ;
}
9.编写函数fun,它的功能是:根据以下公式求P的值,结果由函数值带回。m与n为两个正整数且要求m>n。p=m!/n!(m-n)!。例如:m=12,n=8时,运行结果为495.000000。
♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
#include <conio.h>
#include <stdio.h>
float fun( int m, int n)
{ int i,j,k;
long int t=1,s=1,p=1;
float q;
for(i=1; i<=m; i ) t*=i;
for(j=1; j<=n; j ) s*=j;
for(k=1; k<=m-n; k ) p*=k;
q=(float)t/s/p;
return q;
}
main()
{ printf("\np=%lf\n", fun(12,8));
}