第90题 (20.0分) 难度:中 第1章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:函数fun的功能是:将s所指字符串中除下标为偶数同时ASCII码值也为偶数的字符
外,其余的全部删除;字符串中剩余字符所形成的新串放在t所指的数组中。
例如:若s所指字符串中的内容为"ABCDEFG123456",其中字符A的ASCII码值为奇数,因此应
当删除;字符B的ASCII码值为偶数,但在数组中的下标为奇数,因此也应当删除;字
符2的ASCII码值为偶数,在数组中的下标也为偶数,因此不应当删除,其他依此类推。
最后t所指的数组中的内容应是"246"。
注意:请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入
你编写的若干语句。
-------------------------------------------------------*/
#include <stdio.h>
#include <string.h>
void wwjt ( );
void fun(char *s, char t[])
{
/**********Program**********/
/********** End **********/
}
main()
{
char s[100], t[100];
printf("\nPlease enter string S:");
scanf("%s", s);
fun(s, t);
printf("\nThe result is: %s\n", t);
wwjt();
}
void wwjt ( )
{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */
char s[100], t[100] ;
FILE *in, *out ;
int i ;
in=fopen("in.dat","r");
if(in==NULL)
{
printf("Please Verify The Currernt Dir..It May Be Changed");
}
out=fopen("out.dat","w");
if(out==NULL)
{
printf("Please Verify The Current Dir.. It May Be Changed");
}
for(i = 0 ; i < 10 ; i++)
{
fscanf(in, "%s", s) ;
fun(s, t) ;
fprintf(out, "%s\n", t) ;
}
fclose(in) ;
fclose(out) ;
}
答案: int i,j=0;
for(i=0;s[i]!='\0';i++)
if(i%2==0 && s[i]%2==0)
t[j++]=s[i];
t[j]='\0';
第91题 (20.0分) 难度:易 第2章
/*------------------------------------------------
【程序设计】
--------------------------------------------------
功能:能计算从1开始到n的自然数的和,n由键盘输入,
并在main()函数中输出。
------------------------------------------------*/
#include <stdio.h>
void wwjt();
int fun(int n)
{
/**********Program**********/
/********** End **********/
}
main()
{
int m;
printf("Enter m: ");
scanf("%d", &m);
printf("\nThe result is %d\n", fun(m));
wwjt();
}
void wwjt()
{
FILE *IN,*OUT;
int t;
int o;
int c;
IN=fopen("in.dat","r");
if(IN==NULL)
{
printf("Read FILE Error");
}
OUT=fopen("out.dat","w");
if(OUT==NULL)
{
printf("Write FILE Error");
}
for(c=1;c<=5;c++)
{
fscanf(IN,"%d",&t);
o=fun(t);
fprintf(OUT,"%d\n",o);
}
fclose(IN);
fclose(OUT);
}
答案:----------------------
int sum,i;
sum =0;
for(i=1;i<=n;i++)
{sum=sum+i;}
return(sum);
----------------------
第92题 (20.0分) 难度:中 第1章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:请编写函数fun,该函数的功能是:计算并输出n(包括n)以内所有能被5或9整除的
自然数的倒数之和。
例如:若主函数中从键盘给n输入20后,则输出为S= 0.583333。
注意:n的值要求不大于100。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入
你编写的若干语句。
-------------------------------------------------------*/
#include <stdio.h>
#include <math.h>
void wwjt();
double fun(int n)
{
/**********Program**********/
/********** End **********/
}
void main()
{
int n;
double sum;
printf("Input N=");
scanf("%d",&n);
sum=fun(n);
printf("\n\nsum=%f\n\n",sum);
wwjt();
}
void wwjt()
{
FILE *in, *out;
int i, n;
double sum;
in=fopen("in.dat","r");
if(in==NULL)
{
printf("Please Verify The Currernt Dir..It May Be Changed");
}
out=fopen("out.dat","w");
if(out==NULL)
{
printf("Please Verify The Current Dir.. It May Be Changed");
}
for(i=0;i<10;i++)
{
fscanf(in,"%d",&n);
sum=fun(n);
fprintf(out,"%lf\n",sum);
}
fclose(in);
fclose(out);
}
答案: int m,k,i;
double s=0.0;
for(m=3;m<=n;m++)
{
k=sqrt(m);
for(i=2;i<=k;i++)
if(m%i==0)
break;
if(i>=k+1)
s+=sqrt(m);
}
return s;
第93题 (20.0分) 难度:中 第1章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,
请编写函数fun ,其功能是:把低于平均分的学生数据放入b所指的数组中,低于
平均分的学生人数通过形参n传回,平均分通过函数值返回。
注意:请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入
你编写的若干语句。
-------------------------------------------------------*/
#include <stdio.h>
void wwjt();
#define N 8
typedef struct
{
char num[10];
int s;
} STREC;
double fun( STREC *a, STREC *b, int *n )
{
/**********Program**********/
/********** End **********/
}
main()
{
STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},
{"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87}};
STREC h[N];
int i,n;
double ave;
ave=fun( s,h,&n );
printf("The %d student data which is lower than %7.3f:\n",n,ave);
for(i=0;i<n; i++)
printf("%s %d\n",h[i].num,h[i].s);
printf("\n");
wwjt();
}
void wwjt()
{
FILE *in,*out;
STREC s[N], h[N];
int i,j,n;
double ave;
in=fopen("in.dat","r");
if(in==NULL)
{
printf("Please Verify The Currernt Dir..It May Be Changed");
}
out=fopen("out.dat","w");
if(out==NULL)
{
printf("Please Verify The Current Dir.. It May Be Changed");
}
for(j=0;j<10;j++)
{
for(i=0;i<8;i++)
{
fscanf(in,"%s %d",&s[i].num,&s[i].s);
}
ave=fun( s,h,&n );
fprintf(out, "%d\n%7.3f\n", n, ave);
}
fclose(in);
fclose(out);
}
答案: int i,j=0;
double av=0.0;
for(i=0;i<N;i++)
av=av+a[i].s;
av=av/N;
for(i=0;i<N;i++)
if(a[i].s<av)
b[j++]=a[i];
*n=j;
return av;
第94题 (20.0分) 难度:中 第2章
/*------------------------------------------------
【程序设计】
--------------------------------------------------
功能:求k!(k〈13),所求阶乘的值作为函数值返回。
(要求使用递归)
------------------------------------------------*/
#include <stdio.h>
#include"conio.h"
void wwjt();
long fun(int k)
{
/**********Program**********/
/********** End **********/
}
main()
{
int m;
printf("Enter m: ");
scanf("%d", &m);
printf("\nThe result is %ld\n", fun(m));
wwjt();
}
void wwjt()
{
FILE *IN,*OUT;
int s ;
int t;
long o;
IN=fopen("in.dat","r");
if(IN==NULL)
{
printf("Read FILE Error");
}
OUT=fopen("out.dat","w");
if(OUT==NULL)
{
printf("Write FILE Error");
}
for(s=1;s<=5;s++)
{
fscanf(IN,"%d",&t);
o=fun(t);
fprintf(OUT,"%ld\n",o);
}
fclose(IN);
fclose(OUT);
}
答案:----------------------
if (k>0)
return(k*fun(k-1));
else if(k==0)
return 1L;
----------------------
第95题 (20.0分) 难度:中 第2章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:编写程序计算并输出:1 + 12 + 123 + 1234 + …… 的前n(设0<n<10)项的和sum,
n从键盘输入。
例如输入:3 则输出:136
又如输入:6 则输出:137171
-------------------------------------------------------*/
#include <stdio.h>
void wwjt();
//计算1 + 12 + 123 + 1234 + …… 的前n(设0<n<10)项的和
long sum(int n)
{
/**********Program**********/
/********** End **********/
return sum;
}
main()
{
int n;
printf("Input n: ");
scanf("%d", &n);
printf("sum=%ld\n",sum(n));
wwjt();
}
void wwjt()
{
FILE *IN,*OUT;
int i,j;
IN=fopen("in.dat","r");
OUT=fopen("out.dat","w");
for(i=0;i<3;i++)
{
fscanf(IN,"%d",&j);
fprintf(OUT,"%d\n",sum(j));
}
fclose(IN);
fclose(OUT);
}
答案: int i;
long k, sum;
sum = 0;
k = 0;
for ( i=1; i<=n; i++ )
{
k = 10*k + i;
sum += k;
}
第96题 (20.0分) 难度:中 第1章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:N名学生的成绩已在主函数中放入一个带有头节点的链表结构中,h指向链表的头
节点。请编写函数fun,其功能是:找出学生的最高分,并由函数值返回。
注意:请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入
你编写的若干语句。
-------------------------------------------------------*/
#include <stdio.h>
#include <stdlib.h>
#define N 8
void wwjt ();
struct slist
{
double s;
struct slist *next;
};
typedef struct slist STREC;
double fun( STREC *h )
{
/**********Program**********/
/********** End **********/
}
STREC * creat( double *s)
{
STREC *h,*p,*q; int i=0;
h=p=(STREC*)malloc(sizeof(STREC));
p->s=0;
while(i<N)
{
q=(STREC*)malloc(sizeof(STREC));
q->s=s[i]; i++; p->next=q; p=q;
}
p->next=0;
return h;
}
outlist( STREC *h)
{
STREC *p;
p=h->next; printf("head");
do
{
printf("->%2.0f",p->s);p=p->next;
}
while(p!=0);
printf("\n\n");
}
void main()
{
double s[N]={85,76,69,85,91,72,64,87}, max;
STREC *h;
h=creat( s ); outlist(h);
max=fun( h );
printf("max=%6.1f\n",max);
wwjt();
}
void wwjt ()
{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */
FILE *in, *out ;
int i,j ; double s[N],max;
STREC *h ;
in=fopen("in.dat","r");
if(in==NULL)
{
printf("Please Verify The Currernt Dir..It May Be Changed");
}
out=fopen("out.dat","w");
if(out==NULL)
{
printf("Please Verify The Current Dir.. It May Be Changed");
}
for(i = 0 ; i < 10 ; i++)
{
for(j=0 ; j < N; j++)
fscanf(in, "%lf,", &s[j]) ;
h=creat( s );
max=fun( h );
fprintf(out, "%6.1lf\n", max) ;
}
fclose(in) ;
fclose(out) ;
}
答案: double max=h->s;
while(h!=NULL) /*通过循环找到最高分数*/
{
if(max<h->s)
max=h->s;
h=h->next;
}
return max;
第97题 (20.0分) 难度:中 第2章
/*------------------------------------------------
【程序设计】
--------------------------------------------------
功能:将两个两位数的正整数a、b合并形成一个整数放在
c中。合并的方式是:将a数的十位和个位数依次放
在c数的百位和个位上, b数的十位和个位数依次放
在c数的十位和千位上。
例如:当a=45,b=12。调用该函数后,c=2415。
------------------------------------------------*/
#include <stdio.h>
void wwjt();
void fun(int a, int b, long *c)
{
/**********Program**********/
/********** End **********/
}
main()
{
int a,b; long c;
printf("input a, b:");
scanf("%d%d", &a, &b);
fun(a, b, &c);
printf("The result is: %ld\n", c);
wwjt();
}
void wwjt ( )
{
FILE *rf, *wf ;
int i, a,b ; long c ;
rf = fopen("in.dat", "r") ;
wf = fopen("out.dat","w") ;
for(i = 0 ; i < 10 ; i++)
{
fscanf(rf, "%d,%d", &a, &b) ;
fun(a, b, &c) ;
fprintf(wf, "a=%d,b=%d,c=%ld\n", a, b, c) ;
}
fclose(rf) ;
fclose(wf) ;
}
答案:----------------------
*c=a/10*100+a%10+b/10*10+b%10*1000;
----------------------
第98题 (20.0分) 难度:中 第1章
/*-------------------------------------------------------
【程序设计】
---------------------------------------------------------
题目:已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。
请编写函数fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主
函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。
注意:请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入
你编写的若干语句。
-------------------------------------------------------*/
#include<stdio.h>
#include<string.h>
#include<conio.h>
#include<stdlib.h>
#define N 10
void wwjt();
typedef struct ss /*定义结构体*/
{
char num[10];
int s;
} STU;
void fun(STU a[], STU *s)
{
/**********Program**********/
/********** End **********/
}
void main()
{
STU a[N]={{ "A01",81},{ "A02",89},{ "A03",66},{ "A04",87},{ "A05",77},
{ "A06",90},{ "A07",79},{ "A08",61},{ "A09",80},{ "A10",71}},m;
int i;
system("CLS");
printf("*****The original data*****");
for(i=0;i<N;i++)
printf("No=%s Mark=%d\n", a[i].num,a[i].s);
fun(a,&m);
printf("*****THE RESULT*****\n");
printf("The top :%s, %d\n",m.num,m.s);
wwjt();
}
void wwjt()
{
FILE *in, *out;
STU a[N],m;
int i;
in=fopen("in.dat","r");
if(in==NULL)
{
printf("Please Verify The Currernt Dir..It May Be Changed");
}
out=fopen("out.dat","w");
if(out==NULL)
{
printf("Please Verify The Current Dir.. It May Be Changed");
}
for(i=0; i<10;i++)
{
fscanf(in,"%s %d",&a[i].num,&a[i].s);
}
fun(a,&m);
fprintf(out,"%s,%d",m.num,m.s);
fclose(in);
fclose(out);
}
答案: int i;
*s=a[0];
for(i=0;i<N;i++) /*找出成绩最高的学生记录*/
if(s->s<a[i].s)
*s=a[i];
第99题 (20.0分) 难度:中 第2章
/*------------------------------------------------
【程序设计】
--------------------------------------------------
功能:输入一个字符串,过滤此串,只保留串中的字母字
符,并统计新生成串中包含的字母个数。
例如:输入的字符串为ab234$df4,新生成的串为abdf 。
------------------------------------------------*/
#include <stdio.h>
#include <conio.h>
#define N 80
void wwjt();
fun(char *ptr)
{
/**********Program**********/
/********** End **********/
}
main()
{
char str[N];
int s;
printf("input a string:");gets(str);
printf("The origINal string is :"); puts(str);
s=fun(str);
printf("The new string is :");puts(str);
printf("There are %d char IN the new string.",s);
wwjt();
}
void wwjt()
{
FILE *IN,*OUT;
char sin[N];
int iOUT;
IN=fopen("in.dat","r");
if(IN==NULL)
{
printf("Please Verify The Currernt Dir..it May Be Changed");
}
OUT=fopen("out.dat","w");
if(OUT==NULL)
{
printf("Please Verify The Current Dir.. it May Be Changed");
}
fscanf(IN,"%s",sin);
iOUT=fun(sin);
fprintf(OUT,"%d %s\n",iOUT,sin);
fclose(IN);
fclose(OUT);
}
答案:----------------------
int i,j;
for(i=0,j=0;*(ptr+i)!='\0';i++)
if(*(ptr+i)<='z'&& *(ptr+i)>='a'||*(ptr+i)<='Z' && *(ptr+i)>='A')
{*(ptr+j)=*(ptr+i);
j++;}
*(ptr+j)='\0';
return(j);
----------------------
第100题 (20.0分) 难度:难 第1章
/*------------------------------------------------------------------------
【程序设计】
--------------------------------------------------------------------------
题目:编写函数fun,该函数的数学表达式如样张所示。
程序输出:
fun(-2.1) = -2.100
fun(0.3) = 1.350
fun(1.5) = 0.162
------------------------------------------------------------------------
注意:部分源程序给出如下。请勿改动主函数main或其它函数中给出的内容,仅在
Program-End之间删除【?】填入若干语句。不要删除标志否则不得分。
----------------------------------------------------------------------*/
#include<stdio.h>
#include<math.h>
double fun(double x)
{
double y;
/**********Program**********/
if【?】
【?】;
else if【?】
y= 【?】;
else
【?】;
/********** End **********/
return y;
}
int main()
{
printf("fun(-2.1) = %8.3lf\n", fun(-2.1));
printf("fun(0.3) = %8.3lf\n", fun(0.3));
printf("fun(1.5) = %8.3lf\n", fun(1.5));
}
答案: if(x<-1)
y=x;
else if(x<=1)
y= exp(x);
else
y=log(x)/(x+1);