當前位置:首頁 » 編程語言 » c語言上機題庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言上機題庫

發布時間: 2022-01-15 14:07:23

1. 求推薦一本c語言上機操作的習題本


選擇題(7分,每小題0.5分)
1.C語言源程序的基本單位是( )。
A 過程 B 函數 C 子程序 D 標識符
2.下列程序的輸出結果是( )。
main( )
{ int a=7,b=5;
printf("%d\n",b=b/a);
}
A 5 B 1 C 0 D不確定值
3.假設變數a,b均為整型,表達式(a=5,b=2,a>b?a++:b++,a+b)的值是( )。
A 7 B 8 C 9 D 2
4.設a為int型變數,執行下列賦值語句後,a的取值分別是( )。
a=125.534; a=(int)125.521%4; a=5<<2;
A 125,31,1 B 125,1,20 C 125,31,20 D 125.534,2,20
5.設有如下程序段,下面描述中正確的是 ( )。
int k=10; while(k=0) k=k-1;
A 循環執行一次 B循環是無限循環 C循環體語句一次也不執行 D循環體語句執行一次
6.以下程序的輸出結果為( )。
int i;
void prt( )
{ for(i=5;i<8;i++) printf("%c",'*');
printf("\t");
}
main( )
{ for(i=5;i<=8;i++) prt( );
}
A *** B *** *** *** *** C *** *** D * * *
7.在C語言程序中,以下說法正確的是( )。
A函數的定義可以嵌套,但函數的調用不可以嵌套
B函數的定義不可以嵌套,但函數的調用可以嵌套
C函數的定義和函數的調用都不可以嵌套
D函數的定義和函數的調用都可以嵌套
8.以下函數調用語句中含有( )個實參。
func((e1,e2),(e3,e4,e5));
A 2 B 3 C 5 D 語法錯誤
9.以下程序的輸出結果為( )。
#define ADD(x) x*x
main( )
{ int a=4,b=6,c=7,d=ADD(a+b)*c;
printf("d=%d",d);
}
A d=70 B d=80 C d=140 D d=700
10.已知職工記錄描述如下,在Turbo C中,系統為變數w分配( )位元組的空間。
struct worker
{ int no;
char name[20];
char sex;
union
birth;
} w;
A 29 B 20 C 25 D 6
11.設有以下定義,值為5的枚舉常量是( )。
enum week w;
A tue B sat C fri D thu
12.下面選項中正確的賦值語句是(設 char a[5],*p=a;)( )。
A p="abcd"; B a="abcd"; C *p="abcd"; D *a="abcd";
13.設有以下程序段,則值為6的表達式是( )。
struct st ;
static struct st a[3]=,*p;
p=&a[0];
A p++->n B ++p->n C p->n++ D (*p).n++
14.C語言中的文件類型只有( )。
A 索引文件和文本文件兩種 B 文本文件一種
C 二進制文件一種 D ASCII碼文件和二進制文件兩種
二 判斷對錯,對的劃「√」,錯的劃「×」(5分,每小題0.5分)
1.在Turbo C中,整型數據在內存中佔2個位元組。( )
2.int i=20;switch(i/10)的輸出結果為A。( )
3.break語句用在循環體中,可結束本層循環,continue語句用在循環體中,可結束本次循環。( )
4.函數的遞歸調用不過是一個函數直接或間接地調用它自身。( )
5.函數strlen("ASDFG\n")的值是7。( )
6.通過return語句,函數可以帶回一個或一個以上的返回值。( )
7.結構體類型只有一種。 ( )
8.char *p="girl";的含義是定義字元型指針變數p,p的值是字元串"girl"。( )
9.若有定義:char *p(char a[10]);則p是函數名。( )
10.用fopen("file","r+");打開的文件"file"可以進行修改。 ( )
三 寫出下列程序的運行結果(10分,每小題2分)
1.float average (float array[10])
{ int i;
float aver,sum=array[0];
for (i=1;i<10;i++)
sum=sum+array[i];
aver=sum/10;
return(aver);
}
main( )
,aver;
int i;
aver=average (score);
printf (「average score is %5.2f\n」,aver);
}
2.main( )
,*p=a,**pa;
for(p=0;p<a+5;p++)
printf(「%2c」,*p);
printf(「\n」);
printf(「%2c\n」,**(pa=&p));
}
3.main( )
{ int a,b,s=0;
for(a=1,b=1;a<=100;a++)
{ if(b>=20) break;
if(b%3==1)

b-=5;
}
printf(「a=%d\tb=%d\n」,a,b);
}
4.main()
{ printf(「main( ) :%d\n」,fact(5));
fact(-5);
}
fact(int value)
{ int f;
if(value<0)
{ printf(「Arg error\n");
return(-1);
}
else if(value==1||value==0) f=1;
else f=value*fact(value-1)+1;
printf(「This called value=%d\n」,f);
return f;
}
5.main( )
{ int a=012,b=0x12,k=12;
char c=『\102』,d=『\r』;
printf(「a=%d\tb=%d\tk=%d\n」,a,b,k);
printf(「c=%c,d=%c%o\n」,c,d,a);
a=『A』; c=49;
printf(「a=%d\tc=%c\n」,a,c);
}
四 閱讀下列程序,在 處填入適當內容,使程序完整(8分,每個空1分)
1.有一個3*4矩陣,求其中的最大元素。
max_value( (1) )
{ int i,j,max;
max=array[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(array[i][j]>max)
max=array[i][j];
(2) ;
}
main( )
{ int a[3][4], i,j;
for(i=0;i<3;i++)
for(j=0;j<4;j++)
(3) ;
printf(「max value is %d\n」,max_value(a));
}
2.輸入x、y兩個整數,按先大後小的順序輸出x、y。
#include 「stdio.h」
main( )
{ int x,y, *px,*py, (4) ;
scanf(「%d%d」,&x,&y);
(5) ; (6) ;
if(x<y)

printf(「x=%d,y=%d\n」,x,y);
printf(「MAX=%d,MIN=%d\n」,*px,*py);
}
3.用選擇排序法對任意10個整數按照由小到大排序。
main()
{ int a[11],i,j,k,t;
printf("Please input 10 numbers:\n");
for(i=1;i<11;i++) scanf("%d",&a[i]);
printf("\n");
for(i=1;i<=9;i++)
{ (7) ;
for(j=i+1; (8) ;j++)
if(a[j]>a[k]) k=j;
if(k!=i)

}
printf("The sorted numbers:\n");
for(i=1;i<11;i++) printf("%d ",a[i]);
}
答案

一 選擇題(7分,每小題0.5分)
1. B 2. C 3. B 4. B 5. C
6. A 7. B 8. A 9. A 10. C
11. A 12. A 13. B 14. D
二 判斷對錯,對的劃「√」,錯的劃「×」(5分,每小題0.5分)
1.× 2.× 3.√ 4.√ 5.×
6.× 7.× 8.× 9.√ 10.√
三 寫出下列程序的運行結果(10分,每小題2分)
1. 2. 3.

4. 5.

四 閱讀下列程序,在 處填入適當內容,使程序完整(8分,每個空1分)
1.(1)int array[3][4](int array[][4]) (2)return(max) (3)scanf(「%d」,&a[i][j])
2.(4)*p (5)px=&x(py=&y) (6)py=&y(px=&x)
3.(7) (8

2. 急求全國計算機二級考試C語言上機題庫(10年9月份考的),要有題帶答案的

LZ郵箱我就不發了,告訴你網站
http://www.shangxueba.com/share/s23.html
自己去裡面下載吧!
記得加分哦。。。呵呵

3. 二級C語言上機考試有題庫嘛

上機考試試題
1、填空題
下列給定程序中,函數fun()的作用是:將字元串tt中的大寫字母都改為對應的小寫字母,其他字元不變。例如,若輸入「Ab,cD」,則輸出「ab,cd」。
試題程序:
# include <stdio.h>
# include <stdio.h>
# include <conio.h>
Char【1】fun(char tt[])
{
int i;
for (i=0;tt[i];i++)
{
if ((tt[i]>=』A』)&&(tt[i]<=【2】))
tt[i]+=32;
}
return(tt);
}
main()
{
char tt[81];
printf (「\nPlease enter a string:」);
gets (tt);
printf (「\nThe result string is: \n%s」,fun(【3】));
}
2、改錯題
下列給定程序中,函數fun()的功能是逐個比較a,b兩個字元串對應位置中的字元,把ASCII值小或相等的字元依次存放到c數組中,形成一個新的字元串。
例如:a中的字元串為fshADfg,b中的字元為sdAEdi,則c中的字元串應為fdAADf。
請改正程序中的錯誤,使它能得到正確的結果。
注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。
試題程序:
# include <stdio.h>
# include <string.h>
void fun(char *p,char *q,char *c)
{ int k=0;
while(*p‖*q)
/***************found******************/
{ if (*p<=*q)
c[k]=*q;
else c[k]=*p;
if (*p) p++;
if(*q) q++;
/***************found*******************/
k++
}
}
main()
( char a[10]=」fshADfg」,b[10]=」sdAEdi」,c[80]={『\0』};
fun(a,b,c);
printf(「The string a:」); puts(a);
printf(「The string b:」); puts(b);
printf(「The string c:」); puts(c);
}
3、編程題
請編寫函數fun,其功能是將兩個兩位數的正整數a、b合並形成一個整數放在c中。合並的方式是:將a數的十位和個位數依次放在c數的十位和個位數依次放在c數的百位和千位上。
例如,當a=16,b=35,調用該函數後,c=5361。
注意:部分源程序給出如下。
請勿改動主函數main和其他函數中的任何內容,僅在函數fun的花括弧中填入所編寫的若干語名。
試題程序:
# include<stdio.h>
void fun(int a,int b,long *c)
{

}
main()
{
int a,b;
long c;
clrscr();
printf(「Input a,b;」);
scanf(「%d%d」,&a&b);
fun(a,b,&c);
printf(「The result is:%d\n」,c);
}

4. 全國計算機二級C語言上機試題

http://hi..com/bluewin100/blog/item/6f75cdb1c6146250092302d1.html
這個網址是南開一百題的一個拷貝版的網址 算是word版本的吧 你自己去弄吧

http://learning.sohu.com/s2005/jisuanji.shtml
是我曾經用過的網站 希望對你有幫助

另外 我曾經回答過好多相關的問題 如果有時間 你可以看看我回答過的題目 其中還有相關的備考手段 對你很有好處的
祝你成功哦 (*^__^*) 嘻嘻……

5. 如何把C語言上機軟體中的題庫提取出來

是計算機等級考試嗎?等級考試上機試題是隨機抽取,只抽一次的,其實監考老師特許的情況下,經過他的設置可以重新抽題的,抽一次包括一套的,你可以在迅雷或者網站上下載一個c語言上機考試軟體的,搜一下很容易就找到了,隨便下載一個,是完整的軟體模擬,跟正式考試基本上一樣,操作步驟和題型都一樣,交卷以後電腦可以自動閱卷得分的,還提醒你那做錯了,給你正確答案的,試一下吧!很容易的

6. c語言 上機實操題目

#include<stdio.h>
#include<stdlib.h>

struct node
{
int data;
struct node *next;
};
struct node* create(int n)
{
int i;
struct node *t,*h,*p;

h=t=(struct node*)malloc(sizeof(struct node));
printf("請輸入第1個節點的數據:");
scanf("%d",&(*t).data);
for(i=2;i<=n;i++)
{
p=(struct node*)malloc(sizeof(struct node));
printf("請輸入第%d個節點的數據:",i);
scanf("%d",&(*p).data);
(*t).next=p;
t=p;
}
(*p).next=NULL;
return h;
}
void display(struct node *head)
{
while(head)
{
printf("%d",(*head).data);
if((*head).next)
printf("->");
head=(*head).next;
}
}
void myfree(struct node *head)
{
struct node *p=head;

while(p)
{
head=(*head).next;
free(p);
p=head;
}
}

int main()
{
struct node *head;

head=create(10);
display(head);
myfree(head);
return 0;
}

7. c語言題庫

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Dome2
{
class Student
{
public string name;
public float[] score=new float[3];
public float sum, avg;
public void InitScore()
{
this.sum = 0;
this.avg = 0;
}
public void GetScore()
{
Console.WriteLine("學員姓名:");
this.name = Console.ReadLine();
for (int i = 0; i < score.Length; i++)
{
Console.WriteLine("第{0}門的成績是:",i+1);
this.score[i] = float.Parse(Console.ReadLine());
}
Console.WriteLine();
}
public void GetSum()
{
for (int i = 0; i < score.Length; i++)
{
this.sum+=this.score[i];
}
this.avg = this.sum / 3;
}
public void DisplayScore()
{
Console.WriteLine("學員姓名:{0}", this.name);
for (int j = 0; j < 3; j++)
{
Console.WriteLine("第{0}門課程考試成績是{1}", j + 1, this.score[j]);
} Console.WriteLine("三門課程的總成績是{0},平均成績是{1}",this.sum, this.avg.ToString("0.00"));
Console.WriteLine();
}
}
}

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Dome2
{
class Program
{
static void Main(string[] args)
{
Student[] student = new Student[5];
float max = 0,average = 0;
int i;
int counter = 0;
for (i = 0; i < student.Length; i++)
{
student[i] = new Student();
student[i].GetScore();
student[i].GetSum();
}
for (i = 0; i < student.Length; i++)
{
student[i].DisplayScore();
}
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("========================================================");
for (i = 0; i < student.Length;i++ )
{
counter++;
max = student[i].sum + max;
average = student[i].avg + average;
}
Console.WriteLine("班級參加考試人數:{0} 最高分:{1} 平均分:{2}", counter, max, average);
}
}
}

8. 求 二級c語言上機題庫

二級C語言加油站:http://hi..com/jsj08

9. c語言上機試題

1.m個人的成績存放在score數組中,請編寫函數fun,它的功能是:將低於平均分的人作為函數值返回,將低於平均分的分數放在below所指定的函數中。
1.int fun(int score[],int m,int below[])
{int i,k=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[k]=score[i];
k++;}
return k;}
2.請編寫函數fun,它的功能是:求出1到100之內能北7或者11整除,但不能同時北7和11整除的所有證書,並將他們放在a所指的數組中,通過n返回這些數的個數。
2.void fun(int *a,int *n)
{int i,j=0;
for(i=2;i<1000;i++)
if((i%7==0//i%11==0))&i%77!=0)
a[j++]=i;
*n=j;}
3.請編寫函數void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶數的各整數,並按從小到大的順序放在pp所指的數組中,這些除數的個數通過形參n返回。
3. void fun(int x, int pp[],int *n)
{int i=1,j=0,k=0,*t=pp;
for(i=0;i<=x;i++)
if(i%2!=0)
{t[j]=i;
j++;}
for(i=0;i<j;i++)
if(x%t[i]==0)
{pp[k]=t[i];
k++;}
*n=k;}
4.請編寫一個函數void fun(char *tt,int pp[]),統計在tt字元中"a"到"z"26各字母各自出現的次數,並依次放在pp所指的數組中。
4. void fun(char *tt,int pp[])
{int i;
for(i=0;i<26;i++)
pp[i]=0;
while (*tt)
{switch(*tt)
{case'a':pp[0]++;break;
case'b':pp[1]++;break;
case'c':pp[2]++;break;
case'd':pp[3]++;break;
case'e':pp[4]++;break;
case'f':pp[5]++;break;
case'g':pp[6]++;break;
case'h':pp[7]++;break;
case'i':pp[8]++;break;
case'j':pp[9]++;break;
case'k':pp[10]++;break;
case'l':pp[11]++;break;
case'm':pp[12]++;break;
case'n':pp[13]++;break;
case'o':pp[14]++;break;
case'p':pp[15]++;break;
case'q':pp[16]++;break;
case'r':pp[17]++;break;
case's':pp[18]++;break;
case't':pp[19]++;break;
case'u':pp[20]++;break;
case'v':pp[21]++;break;
case'w':pp[22]++;break;
case'x':pp[23]++;break;
case'y':pp[24]++;break;
case'z':pp[25]++;break;}
tt++;}
}
5.請編寫一個函數void fun(int m,int k,int xx[]),該函數的功能是:將大於整數m且緊靠m的k各素數存入xx所指的數組中。
5. void fun(int m,int k,int xx[])
{int g=0,i,j,flag=1;
for(i=m+1;i<m*m;i++)
{for(j=2;j<i;j++)
{if (i%j!=0)
flag=1;
else
{flag=0;
break;}
}
if (flag==1&j>=i)
{if (k>0)
{xx[g++]=i;
k--;}
else
break;}}}
6.請編寫一個函數void fun(char a[],char[],int n),其功能是:刪除以各字元串中指定下標的字元。其中,a指向原字元串,刪除後的字元串存放在b所指的數組中,n中存放指定的下標。
6. void fun(char a[],char b[],int n)
{int i,j=0;
for (i=0;i<LEN;i++)
if(i!=n)
{b[j]=a[i];
j++;}
b[j]='\0';}
7.請編寫一個函數int fun(int *s,int t,int *k),用來求除數組的最大元素在數組中的下標並存放在k所指的儲存單元中。
7. void 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; }}
8.編寫函數fun,功能是:根據以下攻勢計算s,計算結果作為函數值返回;n通過形參傳入。s=1+1/(1+2)+1/(1+2+3)+.......+1/(1+2+3+4+......+n)
8. float fun(int n)
{int i;
float s=1.0,t=1.0;
for (i=2;i<=n;i++)
{t=t+i;
s=s+1/t;}
return s;}
9.編寫一個函數fun,它的功能是:根據以下公式求P的值,結果由函數值帶回。m與n為兩個正整數,且要求m>n。 p=m!/n!(m-n)!
9. p=m!/n!(m-n)!
float fun(int m,int n)
{float p,t=1.0;
int i;
for (i=1;i<=m;i++)
t=t*i;
p=t;
for (t=1.0,i=1;i<=n;i++)
t=t*i;
p=p/t;
for(t=1.0,i=1;i<m-n;i++)
t=t*i;
p=p/t;
return p;}
10.編寫函數fun,它的功能是:利用以下的簡單迭代方法求方程cos(x)-x=0的一個實根。
迭代步驟如下:(1)取x1初值為0.0; (2)x0=x1,把x1的值賦各x0;
(3)x1=cos(x0),求出一個新的x1;
(4)若x0-x1的絕對值小於0.000001,則執行步驟(5),否則執行步驟(2);
(5)所求x1就是方程cos(x)-x=0的一個實根,作為函數值返回。
程序將輸出Root=0.739085。
10. folat fun()
{float x1=0.0,x0;
do
{x0=x1;
x1=cos(x0); }
while (fabs(x0-x1)>=1e-6);
return x1;}
11.下列程序定義了N×N的二維數組,並在主函數中自動賦值。請編寫函數 fun(int a[][N]),該函數的功能是:使數組左下半三角元素中的值全部置成0。
11. int fun(int a[][N])
{int i,j;
for(i=0;i<N;i++)
for(j=0;j<i;j++)
a[i][j]=0;}
12.下列程序定義了N×N的二維數組,並在主函數中賦值。請編寫函數fun,函數的功能使求出數組周邊元素的平均值並作為函數值返回給主函數中的s。
12.double fun (int w[][N])
{int i,j,k=0;
double s=0.0;
for (j=0;j<N;j++)
{s+=w[0][j];
k++;}
for (j=0;j<N;j++)
{s+=w[N-1][j];
k++;}
for (i=1;i<=N-2;i++)
{s+=w[i][0];
k++;}
return s/=k;}
13.請編寫一個函數void fun(int tt[M][N],int pp[N]),tt指向一個M行N列的二維函數組,求出二維函數組每列中最小元素,並依次放入pp所指定一維數組中。二維數組中的數已在主函數中賦予。
13. void fun(int tt[M][N],int pp[N])
{int i,j,min;
for (j=0;j<N;j++)
{min=tt[0][j];
for (i=0;i<M;i++)
{if (tt[i][j]<min)
min=tt[i][j];}
pp[j]=min;}}
14.請別寫函數fun,函數的功能使求出二維數組周邊元素之和,作為函數值返回。二維數組中的值在主函數中賦予。
14. int fun (int a[M][N])
{int i,j,s=0;
for (j=0;j<N;j++)
{s+=a[0][j];
s+=a[M-1][j];}
for (i=1;i<=M-2;i++)
{s+=a[i][0];
s+=a[i][N-1];}
return s;}
15.請編寫一個函數unsigned fun(unsigned w),w使一個大於10的無符號整數,若w使n(n≥2)位的整數,則函數求出w後n-1位的數作為函數值返回。
15. unsigned fun(unsigned w)
{unsigned t,s=0,s1=1,p=0;
t=w;
while(t>10)
{if(t/10)
p=t%10;
s=s+p*s1;
s1=s1*10;
t=t/10; }
return s;}
16.請編寫一個函數float fun(double h),函數的功能使對變數h中的值保留2位小樹,並對第三位進行四捨五入(規定h中的值位正數)。
16. float fun (float h)
{long t;
float s;
h=h*1000;
t=(h+5)/10;
s=(float)t/100.0;
return s;}
17.請編寫一個函數fun(char *s),該函數的功能使把字元串中的內容擬置。
17. void fun(char *s)
{char ch;
int i,m,n;
i=0;
m=n=strlen(s)-1;
while(i<(n+1)/2)
{ch=s[i];
s[i]=s[m];
s[m]=ch;
i++;
m--;}}
18.編寫程序,實現矩陣(3行3列)的轉置(即行列互換)。
18. void fun(int array[3][3])
{int i,j,temp;
for (i=0;i<3;i++)
{temp=array[i][j];
array[i][j]=array[j][i];
array[j][i]=temp; }}
19.編寫函數fun,該函數的功能是:從字元中刪除指定的字元,同一字母的大、小寫按不同字元處理。
19. void fun(char s[],int c)
{int i=0;
char*p;
p=s;
while(*p)
{if(*p!=c)
{s[i]=*p;
i++;}
p++;}
s[i]='\0';}
20.編寫函數int fun(int lim,int aa[MAX]),該函數的功能是求出小於或等於lim的所有素數並放在aa數組中,該函數返回所求的素數的個數。
20. int fun(int lim,int aa[MAX])
{int k=0,i,j;
for(i=lim;i>1;i--)
{for(j=2;j<i;j++)
if(i%j==0)
break;
else
continue;
if(j>=i)
{aa[k]=i;
k++;}}
return k++;}
21.請編寫函數fun,對長度位7個字元的字元串,除首尾字元外,將其餘5個字元按ASCII碼降序排列。
21.void fun(char *s,int num)
{char t;
int i,j;
for (i=1;i<num-2;i++)
for (j=i+1;j<num-1;j++)
if(s[i]<s[j])
{t=s[i];
s[i]=s[j];
s[j]=t;}}
22.N名學生的成績已在主函數中放入一個帶頭節點的鏈表結構中,h指向鏈表的頭節點。請編寫函數fun,它的功能是:找出學生的最高分,由函數值返回。
22. double fun (STREC *h)
{ double max;
STREC *q=h;
max=h->s;
do
{if(q->s>max)
max=q->s;
q=q->next; }
while(q!=0);
return max;}
23.請編寫函數fun,該函數的功能是:判斷字元串是否為迴文?若是則函數返回1,主函數中輸出YES,否則返回0,主函數中輸出NO。迴文是指順讀和倒讀都是一樣的字元串。
23. int fun(char *str)
{int i,n=0,fg=1;
char *p=str;
while (*p)
{n++;
p++;}
for (i=0;i<n/2;i++)
if (str[i]==str[n-1-i]);
else
{fg=0;
break;}
return fg;}
24.請編寫一個函數fun,它的功能是:將一個字元串轉換為一個整數(不得調用C語言提供的將字元串轉換為整數的函數)。
24. long fun(char *p)
{long s=0,t;
int i=0,j,n=strlen(p),k,s1;
if(p[0]=='-')
i++;
for(j=i;j<=n-1;j++)
{t=p[j]-'0';
s1=10;
for (k=j;k<n-1;k++)
t*=s1;
s+=t; }
if(p[0]=='-')
return -s;
else
return s;}
25.請編寫一個函數fun,它的功能是:比較兩個字元串的長度,(不得調用C語言提供的求字元串長度的函數),函數返回較長的字元串。若兩個字元串長度相同,則返回第一個字元串。
25. char *fun(char *s,char *t)
{char *p,*t1=t,*s1=s;
int n=0,m=0;
while(*s1)
{n++;
s1++;}
while(*t1)
{m++;
t1++;}
if(n>=m)
p=s;
else
p=t;
return p;}
26.請編寫一個函數fun,它的功能是:根據以下公式求X的值(要求滿足精度0.0005,即某項小於0.0005時停止迭代):
X/2=1+1/3+1×2/3×5+1×2×3/3×5×7+1×2×3×4/3×5×7×9+...+1×2×3×...×n/3×5×7×(2n+1)
程序運行後,如果輸入精度0.0005,則程序輸出為3.14...。
26. double fun(double eps)
{double s;
float n,t,pi;
t=1;pi=0;n=1.0;s=1.0;
while((fabs(s))>=eps)
{pi+=s;
t=n/(2*n+1);
s*=t;
n++;}
pi=pi*2;
return pi;}
27.請編寫一個函數fun,它的功能是:求除1到m之內(含m)能北7或11整除的所有整數放在數組a中,通過n返回這些數的個數。
27.void fun(int m,int *a,int *n)
{int i,j;*n=0;
for(i=1;i<=m;i++)
if(i%7==0//i%11==0)
{a[j]=i;
j++;}
*n=j;}
28.請編寫一個函數fun,它的功能是:找出一維整型數組元素中最大的值和它所在的下標,最大的值和它所在的下標通過形參傳回。數組元素中的值已在主函數中賦予。主函數中x是數組名,n 是x中的數據個數,max存放最大值,index存放最大值所在元素的下標。
28. void fun(int a[],int n, int *max,int *d)
{int i;
*max=a[0];
*d=0;
for(i=0;i<n;i++)
if(a[i]>*max)
{*max=a[i];
*d=i;}}
29.請編寫一個函數fun,它的功能是:將ss所指字元串中所有下標為奇數位置上的字母轉換為大寫(若該位置上不是字母,則不轉換)。
29. void fun(char *ss)
{int i,n;
n=strlen(ss);
for(i=1;i<n;i+=2;)
if(ss[i]>='a'&&ss[i]<='z')
ss[i]=ss[i]-32;}
30.請編寫一個函數fun,它的功能是:求除一個2×M整型二維數組中最大元素的值,並將此值返回調用函數。
30. int fun(int a[][M])
{int i,j,max;
max=a[0][0];
for(i=0;i<2;i++)
for(j=0;j<M;j++)
if(a[i][j]>max)
max=a[i][j];
return max;}
31.請編寫函數fun,其功能是:將s所指字元串中除了下標為偶數、同時ASCII值也為偶數的字元外,其餘的全都刪除;串中剩餘字元所形成的一個新串放在t所指的一個數組中。
31. void fun(char *s,char t[])
{int i,j,n;
n=strlen(s);
for(i=0;i<n;i++)
if(i%2==0&s[i]%2==0)
{t[j]=s[j];
j++;}
t[j]='\0';}
32.請編寫函數fun,其功能是:將s所指字元串中除了下標為奇數、同時ASCII值也為奇數的字元之外,其餘的所有字元都刪除,串中剩餘字元所形成的一個新串放在t所指的一個數組中。
32. void fun(char *s,char t[])
{int i,j=0,n;
n=strlen(s);
for(i=0;i<n;i++)
if(i%2!=0&s[i]%2!=0)
{t[j]=s[j];
j++;}
t[j]='\0';}
33.假定輸入的字元串中只包含字母和*號。請編寫函數fun,它的功能是:使字元串中尾部的*號不得多於n個;若多於n個,則刪除多於的*號;若少於或等於n個,則什麼也不做,字元串中間和前面的*號不刪除。
33. void fun(char *a,int n)
{int i=0,k=0;
char *p,*t;
p=t=a;
while(*t)
t++;
t--;
while(*t--'*')
{k++;
t--;}
t++;
if(k>n)
{while(*p&p<t+n)
{a[i]=*p;
i++;
p++;}
a[i]='\0'; }}
34.學生的記錄由學號和成績組成,N名學生的數據已在主函數中放入結構體數組s中,請編寫函數fun,它的功能使:把分數最高的學生數據放在h所指的數組中,注意:分數最高的學生可能不止一個,函數返回分數最高的學生的人數。
34. int fun(STREC*a,STREC *b)
{int i,j=0,max;
max=a[0].s;
for(i=0;i<N;i++)
if(a[i].s==max)
{*(b+j)=a[i];
j++;
n++;}
return n;}
35.請編寫一個函數,用來刪除字元串中的所有空格。
35. void fun(char *str)
{int i=0;
char *p=str;
while(*p)
{if(*p!='')
{str[i]=*p;
i++;}
p++;}
str[i]='\0';}
36.假定輸入的字元串中只包含字母和*號。請編寫函數fun,它的功能是:將字元串中的前導*號全部移到字元串的尾部。
36. void fun(char *a)
{int i=0,n=0;
char *p;
p=a;
while (*p=='*')
{n++;
p++;}
while (*p)
{a[i]=*p;
i++;
p++;}
while(n!=0)
{a[i]='*';
i++;
i--;}
a[i]='\0';}
37.某學生的記錄由學號、8門課程成績和平均分組成,學號和8門課程的成績已在主函數中給出。請編寫函數fun,它的功能是:求出該學生的平均分放在記錄的ave成員中。請自己定義正確的形參。
37. void fun(STREC *p)
{double av=0.0;
int i;
for(i=0;i<N;i++)
av+=p->s[i];
av/=N;
p->ave=av;}
38.請編寫函數fun,它的功能是:求出ss所指字元串中指定字元的個數,並返回此值。
38. int fun(char *ss,char c)
{int n=0;
while(*ss)
{if(*ss==c)
n++;
ss++;}
return n;}
39.請編寫函數fun,該函數的功能是:移動一維數組中的內容,若數組中由n個整數,要求把下標從0到p(p小於等於n-1)的數組元素平移到數組的最後。
39. void fun(int *w,int p,int n)
{int b[N],i,j=0;
for(i=0;i<=p;i++)
b[i]=w[i];
for(i=p+1;i<n;i++)
{w[j]=w[i];
j++;}
for(i=0;i<=p;i++)
{w[j]=b[i];
j++;}}
40.請編寫函數fun,該函數的功能是移動字元串中內容,移動的規則如下:把第1到第m個字元,平移到字元串的最後,把第m+1到最後的字元移到字元串的前部。
40.void fun(char *w,int m)
{char b[N];
int i,j=0;
for(i=0;i<m;i++)
{b[j]=w[i];
j++;}
for(i=0;i<strlen(w)-m;i++)
w[i]=w[i+m];
for(j=0;j<m;j++)
{w[i]=b[j];
i++;}
w[i]='\0';}
41.請編寫函數fun,該函數的功能是:將M行N列的二維數組中的字元數據,按列的順序依次放到一個字元串中。
41. void fun(char (*s)[N],char *b)
{int i,j,k=0;
for(j=0;j<n;j++)
for(i=0;i<M;i++)
{b[k]=*(*(s+i)+j)
k++;}
b[k]='\0';}
42.下列程序定義了N×N的二維數組,並在主函數中自動賦值。請編寫函數fun(int a[][N],int m),該函數的功能是:將數組右上半三角元素中的值乘以m。

42. void fun(int a[][N],int m)
{int i,j;
for(j=0;j<N;j++)
for(i=0;i<=j;i++)
a[i][j]=a[i][j]*m;}
43.編寫一個函數,從傳入的num個字元串中找出一個最長的一個字元串,並通過形參指針max傳回該串地址(用****作為結束輸入的標志)。
43. char *fun(char (*a)[81],int num)
{int i;
char *max;
max=a[0];
for(i=0;i<num;i++)
if(strlen(max)<strlen(a[i]))
max=a[i];
return max;}
44.編寫一個函數,該函數可以統計一個長度為2的字元串在另一個字元串中出現的次數。
44. int fun(char *str,char *substr)
{int n;
char *p,*r;
n=0;
while(*str)
{p=str;
r=substr;
while(*r)
if(*r==*p)
{r++;
p++;}
else
break;
if(*r=='\0')
n++;
str++;}
return n;}
45.假定輸入的字元串中只包含字母和*號。請編寫函數fun,它的功能是:只刪除字元串前導和尾部的*號,串中字母之間的*號都不刪除。形參n 給出了字元串的長度,形參h給出了字元串中前導*號的個數,形參e給出了字元串中最後的*個數。在編寫時不得使用C語言給提供得字元串函數。
45.void fun(char *a,int n,int h,int e)
{int i=0;
char *p;
for(p=a+h;p<a+n-e;p++)
{*(a+i)=*p;
i++;}
*(a+i)='\0';}
46.學生得記錄由學號和成績組稱個,N名大學生得數據已在主函數中放入結構體數組s中,請編寫函數fun,它的功能時:按分數的高低排列學生的記錄,高分在前。
46. void fun(STREC a[])
{int i,j;
STREC t;
for(i=0;i<N-1;i++)
for(j=i;s<N;j++)
if(a[i].s<a[j].s)
{t=a[i];
a[i]=a[j];
a[j]=t; }}
47.請編寫一個函數void fun(char *ss),其功能時:將字元串ss中所有下標為奇數位置上的字母轉換為大寫(若位置上不是字母,則不轉換)。
47. void fun(char *ss)
{int i,n=0;
char *p=ss;
while(*p)
{n++;
p++;}
for (i=0;i<n;i++)
if ((ss[i]='a'&ss[i]<='z')
ss[i]=ss[i]-32;
ss[i]='\0';}
48.請編寫函數fun,其功能是:將兩個兩位數的正整數a,b合並成一個整數放在c中。合並的方式是:將a數的十位和個位依次放在c數的千位和十位上,b數的十位和個位數依次放在c數的百位和個位上。
48. void fun(int a,int b,long *c)
{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}
49.請編寫函數fun,其功能是:將s所指字元串中下標位偶數同時ASCII值為奇數的字元刪除,s中剩餘的字元形成的新串放在t所指的數組中。
49. void fun(char *s,char t[])
{int i,j=0,n=strlen(s);
for(i=0;i<n;i++)
if(i%2==0&s[i]%2!=0)
else
{f[j]=s[i];
j++;}
t[j]='\0';}
50.已知學生的記錄是由學號和學習成績構成,N名學生的數據已存入結構體數組中。請編寫函數fun,該函數的功能是:找出成績最高的學生記錄,通過形參返回主函數(規定只有一個最高分)。
50. void fun(STU a[],STU *s)
{int i,max;
max=a[0].s;
for (i=0;i<N;i++)
if(a[i].s>max)
{max=a[i].s;
*s=a[i];}}
51.請編寫函數fun,其功能是:將所有大於1小於整數m的非素數存入xx所指的數組中,非素數的個數通過k傳回。
51. void fun(int m,int *k,int xx[])
{int i,j;
int t=0;
for(i=2;i<m;i++)
{j=2;
while(j<i)
{if(i%j==0)
{xx[t]=i;
t++;
break;}
j++;}
*k=t;}}
52.編寫一個函數fun,它的功能是:實現兩個字元串的連接(不使用庫函數strcat),即把p2所指的字元串連接到p1所指的字元串後。
52. void fun(char p1[],char p2[])
{int i=0,n=0;
char *p=p1,*q=p2;
while (*p)
{p++;
n++;}
i=n;
while(*p)
{p1[i]=*q;
q++;
i++;}
p1[i]='\0';}
53.請編寫函數fun,該函數的功能是:實現B=A+A',即把矩陣A加上A的轉置,存放在矩陣B中。計算結果在main函數中輸出。
53. void fun(int a[3][3],int b[3][3])
{int i,j,at[3][3];
for(i=0;i<=2;i++)
for(j=0;j<=2;j++)
at[i][j]=a[j][i];
for(i=0;i<3;i++)
for(j=0;j<3;j++)
b[i][j]=a[i][j]+at[i][j];}
54.學生的記錄由學號和成績組稱個,N名學生的數據已在主函數中放入結構體數組s中,請編寫函數fun,它的功能是:把低於平均分的學生數據放在b所指的數組中,低於平均分的學生人數通過形參n傳回,平均分通過函數值返回。
54. double fun(STREC *a, STREC *b,int *n)
{double aver=0.0;
int i,j=0;
*n=0;
for (i=0;i<N;i++)
aver+=a[i].s;
aver/=N;
for(i=0;i<N;i++)
if(a[i].s<aver)
{b[j]=a[i];
(*n)++;
j++; }
return aver;}