当前位置:首页 > 黑客接单 > 正文内容

c语言100题(c语言100题电子版)

hacker3年前 (2022-06-03)黑客接单153

本文导读目录:

c语言编程实例100题

这里非常不错,不但有经典的100例,还有许多实用的例子,强烈推荐!!

http://tieba.baidu.com/f?kz=13382217

C语言题目,100分悬赏

之一题:已知某班N(〈=50)名学生进行了高数、英语和C语言等3门课考试,将3门课的成绩以及计算3门课的总分存放于一个二维数组中,将学生姓名存放在另一个二维字符数组中,按总分(由高到低)将学生姓名排序并输出排序结果(序号和姓名)。

#includestdio.h

#includestring.h

#define N 50

typedef struct

float mark[4];

long number;

char name[25];

}JD;

JD stu[N];

void sort(JD stu[],int n)

int i,j;

JD temp;

for(i=1;i=n;i++)

for(j=1;j=n-i;j++)

if(stu[j].mark[4]stu[j+1].mark[4])

temp=stu[j];

stu[j]=stu[j+1];

stu[j+1]=temp;

main()

int i,n;

printf("请输入学生数:\n");

scanf("%d",n);

for(i=1;i=n;i++)

printf("请输入第%d个学生的信息(包括学号、姓名、高数成绩、英语成绩、c语言成绩):\n",i);

scanf("%ld%s",stu[i].number,stu[i].name);

scanf("%f%f%f",stu[i].mark[1],stu[i].mark[2],stu[i].mark[3]);

for(i=1;i=n;i++)

stu[i].mark[4]=0;

stu[i].mark[4]=stu[i].mark[1]+stu[i].mark[2]+stu[i].mark[3];

sort(stu,n);

printf("排序的结果是:\n");

for(i=1;i=n;i++)

printf("第%d名同学是:",i);

printf("%ld\t%s\n",stu[i].number,stu[i].name);

第二题:编写函数fun(char s[ ], int num[ ]),其功能是统计字符串 s 中数字字符、大写字母、小写字母和空格字符的出现次数,统计结果存于num数组中。再设计main函数,调用fun函数,实现预期功能。

#includestdio.h

#define N 10

void fun(char s[], int num[])

int i;

for(i=0;s[i]!='\0';i++)

if(s[i]='0's[i]='9')

num[0]++;

else if(s[i]='a's[i]='z')

num[1]++;

else if(s[i]='A's[i]='Z')

num[2]++;

else if(s[i]==' ')

num[3]++;

main()

int num[4],i,j;

char s[N];

for(i=0;i4;i++)

num[i]=0;

printf("please input the string:\n");

for(i=0;iN;i++)

scanf("%c",s[i]);

printf("the string is:\n");

for(i=0;iN;i++)

printf("%c",s[i]);

fun(s,num);

printf("\n此字符串中数字字符出现的次数:\n");

printf("\t%d",num[0]);

printf("\n此字符串中小写字母出现的次数:\n");

printf("\t%d",num[1]);

printf("\n此字符串中大写字母出现的次数:\n");

printf("\t%d",num[2]);

printf("\n此字符串中空格字符出现的次数:\n");

printf("\t%d",num[3]);

第三题:编程输出右边图形,其行数n (= 26)由输入而定。 A

A B A

A B C B A

A B C D C B A

#include stdio.h

main ()

int i,j,k;

int a,n;

printf("please input your low:\n");

scanf("%d",n);

for(i=1;i=n;i++)

for(j=1;j=n-i;j++)

printf(" ");

a=65;

for(k=1;k=i;k++)

printf("%c",a++);

for(k=1;ki;k++)

printf("%c",--a-1);

printf("\n");

c语言经典例题100道。

http://wenku.baidu.com/link?url=17ecp5bFRtU7gKxNtkQSEBeRroL2FcF8VypSR-WjxIm_KjwkSY5LTFh9st3RmAN4j-2KUeS1N8rY4yr-ftDBEpqEsViAS1lHqABhA1RyD3W

看看这个,免费下载!希望你能采纳!

c语言问题

您好,c语言经典100题:

【程序1】

题目:有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数 都是多少

1.程序分析:可填在百位,十位,个位的数字都是1,2,3,4.组成所有的排列后再去

掉不满足条件的排列.

2.程序源代码:

main()

int i,j,k;

printf("\n");

for(i1;i5;i++) /*以下为三重循环*/

for(j1;j5;j++)

for (k1;k5;k++)

if (i!ki!jj!k) /*确保i,j,k三位互不相同*/

printf("%d,%d,%d\n",i,j,k);

【程序2】

题目:企业发放的奖金根据利润提成.利润(i)低于或等于10万元时,奖金可提10%;利润高

于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提

成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于

40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于

100万元时,超过100万元的部分按1%提成,从键盘输入当月利润i,求应发放奖金总数

1.程序分析:请利用数轴来分界,定位.注意定义时需把奖金定义成长整型.

2.程序源代码:

main()

long int i;

int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;

scanf("%ld",i);

bonus1100000*0.1;bonus2bonus1+100000*0.75;

bonus4bonus2+200000*0.5;

bonus6bonus4+200000*0.3;

bonus10bonus6+400000*0.15;

if(i100000)

bonusi*0.1;

else if(i200000)

bonu *** onus1+(i-100000)*0.075;

else if(i400000)

bonu *** onus2+(i-200000)*0.05;

else if(i600000)

bonu *** onus4+(i-400000)*0.03;

else if(i1000000)

bonu *** onus6+(i-600000)*0.015;

else

bonu *** onus10+(i-1000000)*0.01;

printf("bonus%d",bonus);

【程序3】

题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少

1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后

的结果满足如下条件,即是结果.请看具体分析:

2.程序源代码:

#include "math.h"

main()

long int i,x,y,z;

for (i1;i2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++;

printf("it is the %dth day.",sum);}

【程序4】

题目:输入某年某月某日,判断这一天是这一年的第几天?

1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊

情况,闰年且输入月份大于3时需考虑多加一天。

2.程序源代码:

main()

int day,month,year,sum,leap;

printf("\nplease input year,month,day\n");

scanf("%d,%d,%d",year,month,day);

switch(month)/*先计算某月以前月份的总天数*/

case 1:sum0;break;

case 2:sum31;break;

case 3:sum59;break;

case 4:sum90;break;

case 5:sum120;break;

case 6:sum151;break;

case 7:sum181;break;

case 8:sum212;break;

case 9:sum243;break;

case 10:sum273;break;

case 11:sum304;break;

case 12:sum334;break;

default:printf("data error");break;

sumsum+day; /*再加上某天的天数*/

if(year%4000||(year%40year%100!0))/*判断是不是闰年*/

leap1;

else

leap0;

if(leap1month2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++;

printf("It is the %dth day.",sum);}

【程序5】

题目:输入三个整数x,y,z,请把这三个数由小到大输出.

1.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果xy则将x与y的值进行交换,

然后再用x与z进行比较,如果xz则将x与z的值进行交换,这样能使x最小.

2.程序源代码:

main()

int x,y,z,t;

scanf("%d%d%d",x,y,z);

if (xy)

{tx;xy;yt;} /*交换x,y的值*/

if(xz)

{tz;zx;xt;}/*交换x,z的值*/

if(yz)

{ty;yz;zt;}/*交换z,y的值*/

printf(" *** all to big: %d %d %d\n",x,y,z);

【程序6】

题目:用*号输出字母c的图案.

1.程序分析:可先用'*'号在纸上写出字母c,再分行输出.

2.程序源代码:

#include "stdio.h"

main()

printf("hello c-world!\n");

printf(" ****\n");

printf(" *\n");

printf(" * \n");

printf(" ****\n");

【程序7】

题目:输出特殊图案,请在c环境中运行,看一看,very beautiful!

1.程序分析:字符共有256个.不同字符,图形不一样.

2.程序源代码:

#include "stdio.h"

main()

char a176,b219;

printf("%c%c%c%c%c\n",b,a,a,a,b);

printf("%c%c%c%c%c\n",a,b,a,b,a);

printf("%c%c%c%c%c\n",a,a,b,a,a);

printf("%c%c%c%c%c\n",a,b,a,b,a);

printf("%c%c%c%c%c\n",b,a,a,a,b);}

【程序8】

题目:输出9*9口诀.

1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列.

2.程序源代码:

#include "stdio.h"

main()

int i,j,result;

printf("\n");

for (i1;i10;i++)

{ for(j1;j10;j++)

resulti*j;

printf("%d*%d%-3d",i,j,result);/*-3d表示左对齐,占3位*/

printf("\n");/*每一行后换行*/

【程序9】

题目:要求输出国际象棋棋盘.

1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格.

2.程序源代码:

#include "stdio.h"

main()

int i,j;

for(i0;i8;i++)

for(j0;j8;j++)

if((i+j)%20)

printf("%c%c",219,219);

else

printf(" ");

printf("\n");

【程序10】

题目:打印楼梯,同时在楼梯上方打印两个笑脸.

1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数.

2.程序源代码:

#include "stdio.h"

main()

int i,j;

printf("\1\1\n");/*输出两个笑脸*/

for(i1;i11;i++)

for(j1;ji;j++)

printf("%c%c",219,219);

printf("\n");

【程序11】

题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月

后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少

1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....

2.程序源代码:

main()

long f1,f2;

int i;

f1f21;

for(i1;i20;i++)

{ printf("%12ld %12ld",f1,f2);

if(i%20) printf("\n");/*控制输出,每行四个*/

f1f1+f2; /*前两个月加起来赋值给第三个月*/

f2f1+f2; /*前两个月加起来赋值给第三个月*/

【程序12】

题目:判断101-200之间有多少个素数,并输出所有素数.

1.程序分析:判断素数的 *** :用一个数分别去除2到sqrt(这个数),如果能被整除,

则表明此数不是素数,反之是素数.

2.程序源代码:

#include "math.h"

main()

int m,i,k,h0,leap1;

printf("\n");

for(m101;m200;m++)

{ ksqrt(m+1);

for(i2;ik;i++)

if(m%i0)

{leap0;break;}

if(leap) {printf("%-4d",m);h++;

if(h%100)

printf("\n");

leap1;

printf("\nthe total is %d",h);

2010南开c语言100上机题库

计算机二级C语言上机南开100题--1

1: 第1题 m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。

答案:

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: 第2题 请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有证书,并将他们放在a所指的数组中,通过n返回这些数的个数。

答案:

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: 第3题 请编写函数void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。

答案:

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: 第4题 请编写一个函数void fun(char *tt,int pp[]),统计在tt字符中"a"到"z"26各字母各自出现的次数,并依次放在pp所指的数组中。

答案:

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[12]++;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: 第5题 请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k各素数存入xx所指的数组中。

答案:

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=0;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: 第6题 请编写一个函数void fun(char a[],char[],int n),其功能是:删除以各字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。

答案:

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: 第7题 请编写一个函数int fun(int *s,int t,int *k),用来求除数组的更大元素在数组中的下标并存放在k所指的储存单元中。

答案:

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: 第8题 编写函数fun,功能是:根据以下攻势计算s,计算结果作为函数值返回;n通过形参传入。S=1+1/(1+2)+1/(1+2+3)+…….+1/(1+2+3+4+……+n)

答案:

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: 第9题 编写一个函数fun,它的功能是:根据以下公式求p的值,结果由函数值带回。M与n为两个正整数,且要求mn。 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: 第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。

答案:

float fun()

float x1=0.0,x0;

do

x0=x1;

x1=cos(x0);

while(fabs(x0-x1)1e-6);

return x1;

11: 第11题 下列程序定义了n×n的二维数组,并在主函数中自动赋值。请编写函数 fun(int a[][n]),该函数的功能是:使数组左下半三角元素中的值全部置成0。

答案:

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: 第12题 下列程序定义了n×n的二维数组,并在主函数中赋值。请编写函数fun,函数的功能使求出数组周边元素的平均值并作为函数值返回给主函数中的s。

答案:

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++;

for(i=1;i<=N-2;i++)

s+=w[i][N-1];

k++;

return s/=k;

13: 第13题 请编写一个函数void fun(int tt[m][n],int pp[n]),tt指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中。二维数组中的数已在主函数中赋予。

答案:

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: 第14题 请别写函数fun,函数的功能使求出二维数组周边元素之和,作为函数值返回。二维数组中的值在主函数中赋予。

答案:

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: 第15题 请编写一个函数unsigned fun(unsigned w),w使一个大于10的无符号整数,若w使n(n≥2)位的整数,则函数求出w后n-1位的数作为函数值返回。

答案:

unsigned fun(unsigned w)

unsigned t,s=0,s1=1,p=0;

t=w;

while(t10)

if(t/10)

p=t%10;

s=s+p*s1;

s1=s1*10;

t=t/10;

return s;

16: 第16题 请编写一个函数float fun(double h),函数的功能使对变量h中的值保留2位小树,并对第三位进行四舍五入(规定h中的值位正数)。

答案:

float fun(float h)

long t;

float s;

h=h*1000;

t=(h+5)/10;

s=(float)t/100.0;

return s;

17: 第17题 请编写一个函数fun(char *s),该函数的功能使把字符串中的内容拟置。

答案:

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: 第18题 编写程序,实现矩阵(3行3列)的转置(即行列互换)。

答案:

void fun(int array[3][3])

int I,j,temp;

for(i=0;i<3;i++)

for(j=0;j<I,j++)

temp=array[i][j];

array[i][j]=array[j][i];

array[j][i]=temp;

19: 第19题 编写函数fun,该函数的功能是:从字符中删除指定的字符,同一字母的大、小写按不同字符处理。

答案:

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: 第20题 编写函数int fun(int lim,int aa[max]),该函数的功能是求出小于或等于lim的所有素数并放在aa数组中,该函数返回所求的素数的个数。

答案:

int fun(int lim, int aa[MAX])

int k=0,I,j;

for(i=lim;i1;i--)

for(j=2;j<i;j++)

if(i%j==0)

break;

else

continue;

if(j=i)

aa[k]=i;

k++;

return k++;

21: 第21题 请编写函数fun,对长度位7个字符的字符串,除首尾字符外,将其余5个字符按ascii码降序排列。

答案:

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: 第22题 n名学生的成绩已在主函数中放入一个带头节点的链表结构中,h指向链表的头节点。请编写函数fun,它的功能是:找出学生的更高分,由函数值返回。

答案:

double fun(STREC *h)

double max;

STREC *q=h;

max=h-s;

do

if(q- *** ax)

max=q-s;

q=q-next;

while(q!=0);

return max;

23: 第23题 请编写函数fun,该函数的功能是:判断字符串是否为回文?若是则函数返回1,主函数中输出yes,否则返回0,主函数中输出no。回文是指顺读和倒读都是一样的字符串。

答案:

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: 第24题 请编写一个函数fun,它的功能是:将一个字符串转换为一个整数(不得调用c语言提供的将字符串转换为整数的函数)。

答案:

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: 第25题 请编写一个函数fun,它的功能是:比较两个字符串的长度,(不得调用c语言提供的求字符串长度的函数),函数返回较长的字符串。若两个字符串长度相同,则返回之一个字符串。

答案:

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: 第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…。

答案:

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: 第27题 请编写一个函数fun,它的功能是:求除1到m之内(含m)能北7或11整除的所有整数放在数组a中,通过n返回这些数的个数。

答案:

void fun(int m, int *a, int *n)

int I,j=0; *n=0;

for(i=1;i<=m;i++)

if (i%7==0 || i%11 ==0)

a[j]=I;

j++;

*n=j;

28: 第28题 请编写一个函数fun,它的功能是:找出一维整型数组元素中更大的值和它所在的下标,更大的值和它所在的下标通过形参传回。数组元素中的值已在主函数中赋予。主函数中x是数组名,n 是x中的数据个数,max存放更大值,index存放更大值所在元素的下标。

答案:

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: 第29题 请编写一个函数fun,它的功能是:将ss所指字符串中所有下标为奇数位置上的字母转换为大写(若该位置上不是字母,则不转换)。

答案:

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: 第30题 请编写一个函数fun,它的功能是:求除一个2×m整型二维数组中更大元素的值,并将此值返回调用函数。

答案:

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: 第31题 请编写函数fun,其功能是:将s所指字符串中除了下标为偶数、同时ascii值也为偶数的字符外,其余的全都删除;串中剩余字符所形成的一个新串放在t所指的一个数组中。

答案:

void fun(char *s,char t[])

int I,j=0,n;

n=strlen(s);

for(i=0;I,n;i++)

if(i%2==0s[i]%2==0)

t[j]=s[i];

j++;

t[j]=‘\0’;

32: 第32题 请编写函数fun,其功能是:将s所指字符串中除了下标为奇数、同时ascii值也为奇数的字符之外,其余的所有字符都删除,串中剩余字符所形成的一个新串放在t所指的一个数组中。

答案:

void fun(char *s,char t[])

int I,j=0,n;

n=strlen(s);

for(i=0;I,n;i++)

if(i%2!=0s[i]%2!=0)

t[j]=s[i];

j++;

t[j]=‘\0’;

33: 第33题 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:使字符串中尾部的*号不得多于n个;若多于n个,则删除多于的*号;若少于或等于n个,则什么也不做,字符串中间和前面的*号不删除。

答案:

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(kn)

while (*pp<t+n)

a[i]=*p;

i++;

p++;

a[i]=‘\0’;

34: 第34题 学生的记录由学号和成绩组成,n名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能使:把分数更高的学生数据放在h所指的数组中,注意:分数更高的学生可能不止一个,函数返回分数更高的学生的人数。

答案:

int fun (STREC *a, STREC *b)

int I,j=0,n=0, max;

max=a[0].s;

for(i=0;i<N;i++)

if(a[i]. *** ax)

max=a[i].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: 第36题 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:将字符串中的前导*号全部移到字符串的尾部。

答案:

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++;

n--;

a[i]=‘\0’;

37: 第37题 某学生的记录由学号、8门课程成绩和平均分组成,学号和8门课程的成绩已在主函数中给出。请编写函数fun,它的功能是:求出该学生的平均分放在记录的ave成员中。请自己定义正确的形参。

答案:

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: 第38题 请编写函数fun,它的功能是:求出ss所指字符串中指定字符的个数,并返回此值。

答案:

int fun(char *ss, char c)

int n=0;

while (*ss)

if(*ss==c)

n++;

ss++;

return n;

39: 第39题 请编写函数fun,该函数的功能是:移动一维数组中的内容,若数组中由n个整数,要求把下标从0到p(p小于等于n-1)的数组元素平移到数组的最后。

答案:

void fun(int *w, int p, int n)

int b[N], i, j=0;

for(i=0;i<=p;i++)

b[i]=w[i];

j++;

for(i=0;i<=p;i++)

w[j]=b[i];

j++;

40: 第40题 请编写函数fun,该函数的功能是移动字符串中内容,移动的规则如下:把第1到第m个字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。

答案:

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: 第41题 请编写函数fun,该函数的功能是:将m行n列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。

答案:

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: 第42题 下列程序定义了n×n的二维数组,并在主函数中自动赋值。请编写函数fun(int a[][n],int n),该函数的功能是:将数组右上半三角元素中的值乘以m。

答案:

void fun(int a[][n],int m)

{int i,j;

for(j=0;j<n;j++)

for(i=0;i<=j;i++)

a[j]=a[j]*m;}

43: 第43题 编写一个函数,从传入的num个字符串中找出一个最长的一个字符串,并通过形参指针max传回该串地址(用****作为结束输入的标志)。

答案:

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))

max=a;

return max;}

44: 第44题 编写一个函数,该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数。

答案:

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: 第45题 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:只删除字符串前导和尾部的*号,串中字母之间的*号都不删除。形参n 给出了字符串的长度,形参h给出了字符串中前导*号的个数,形参e给出了字符串中最后的*个数。在编写时不得使用c语言给提供得字符串函数。

答案:

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: 第46题 学生得记录由学号和成绩组称个,n名大学生得数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能时:按分数的高低排列学生的记录,高分在前。

答案:

void fun(strec a[])

{int i,j;

strec t;

for(i=0;i<n-1;i++)

for(j=i;s<n;j++)

if(a.s<a[j].s)

{t=a;

a=a[j];

a[j]=t; }}

47: 第47题 请编写一个函数void fun(char *ss),其功能时:将字符串ss中所有下标为奇数位置上的字母转换为大写(若位置上不是字母,则不转换)。

答案:

void fun(char *ss)

{int i,n=0;

char *p=ss;

while(*p)

{n++;

p++;}

for (i=0;i<n;i++)

if ((ss=‘a’ss<=‘z’)i%2!=0)

ss=ss-32;

ss=‘\0’;}

48: 第48题 请编写函数fun,其功能是:将两个两位数的正整数a,b合并成一个整数放在c中。合并的方式是:将a数的十位和个位依次放在c数的千位和十位上,b数的十位和个位数依次放在c数的百位和个位上。

答案:

void fun(int a,int b,long *c)

{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}

49: 第49题 请编写函数fun,其功能是:将s所指字符串中下标位偶数同时ascii值为奇数的字符删除,s中剩余的字符形成的新串放在t所指的数组中。

答案:

void fun(char *s,char t[])

{int i,j=0,n=strlen(s);

for(i=0;i<n;i++)

if(i%2==0s%2!=0)

else

{f[j]=s;

j++;}

t[j]=‘\0’;}

50: 第50题 已知学生的记录是由学号和学习成绩构成,n名学生的数据已存入a机构体数组中。请编写函数fun,该函数的功能是:找出成绩更高的学生记录,通过形参返回主函数(规定只有一个更高分)。

答案:

void fun(stu a[],stu *s)

{int i,max;

max=a[0].s;

for (i=0;i<n;i++)

if(a. *** ax)

{max=a.s;

*s=a;}}

C语言100题【程序90】 题目:专升本一题,读结果.为什么输出结果是12345??

while 执行了五次,下面是五次的a里的数据

5 2 3 4 1

5 4 3 2 1

5 4 3 2 1

5 2 3 4 1

1 2 3 4 5

换了又被换回去了,如果要真正实现交换,应该只执行5/2次

c语言问题100

你的这句话应该说“传值类型的形参值得改变并不能改变对应实参的值,把数据从被调用函数返回到调用函数的唯一途径是通过return语句返回函数值”

扫描二维码推送至手机访问。

版权声明:本文由黑客24小时在线接单网站发布,如需转载请注明出处。

本文链接:https://www.cn-sl.com/115897.html

标签: c语言100题
分享给朋友:

“c语言100题(c语言100题电子版)” 的相关文章

vc币价是多少(我有10个比特币怎么卖掉)

OKEx比特币生意业务 所的脚绝费寰球最低.点击,本日 此时比特币价钱  二 三 四 九元,您当然否以一个一个的售没,缘故原由 您懂的。 如今 是 四0- 五0阁下 。比特币是来博门的生意业务 仄台生意 的,p/ 二0 一 一0 六 二0/ 二 六-有 一 七 六 二 八 二0 九jpg,杂外文的,...

荣耀9上市时间 - 荣耀9多久上市时间

枯耀 九曾经上市,今朝 华为商乡枯耀 九有如下版原:枯耀 九齐网通标配版 四GB+ 六 四GB¥ 二 二 九 九,根本 设置装备摆设 以下: 一。 知更鸟蓝多种配色否选,枯耀 九未于 二0 一 七年 六月份上市。华为商乡价钱 以下: 四+ 六 四G版 二 二 九 九元; 六,魅海蓝、枯耀旗高的一款智...

江西抚州2地发布疫情防控通报

  起源 |都会 现场综折魅力抚州下新、东城宣布   已经许可 没有患上转载 如增除了起源 必究      闭于湖北省娄底市   境中输出新冠阴性检测者   稀交职员 马某、田某、梁某、潘某等   四人行为 轨迹通知布告    二0 二 一年 九月 二 七日下昼  五:00,尔部支...

今天的汽油单价 - 今日燃油价格最新行情

 四点 五 九元调为 五点0 二元,分歧 批次价钱 会有差距,常常 堵车路况差的情形 高, 九 三#汽油 七点 七 一元/降、 二0: 二 九单元 :群众币,情形 昨天整时起。  九 二号汽油,0 号柴油每一降上浮0点0 四元。更别说分歧 地域 了, 九 二号汽油,上浮0点 三 七止情元; 九 三号...

哪些人员可以报考面向服务基层项目人员定向招录的职位 哪些人员可以报考面向服务基层项目人员定向招录的职位

 二0 二 一地津公事 员测验 通知布告 ( 二 二0 六人)未宣布 !报名空儿: 二0 二 一年 三月 三日 八:00至 三月 九日,口试 空儿为 三月 二 七日、 二 八日。为便利 宽大 考熟相识  二0 二 一地津市考报考相闭答题,外私学育地津频叙特殊 整顿 了相闭内容,如下为 二0 二 ...

电刷是什么(电刷是什么东西)

甚么是单绞线?起首 从字母装分去看,R代表硬线,V代表PVC(续缘体),S代表单绞线。这咱们否以鸣RVSPVC续缘绞硬线。而且 铜导体的字母l否以省略。以是 否以很孬的懂得 RVS的齐称是铜芯PVC续缘多股硬线。从中不雅 上看,RVS是由二条RV线交错 而成,雅称单绞线、麻花线、花线等。由于 那种电...

评论列表

怎忘森槿
3年前 (2022-06-04)

typedef struct{ float mark[4]; long number; char name[25];}JD;JD stu[N];void sort(JD stu[],int n){ int i,j; JD temp; for(i=

嘻友简妗
3年前 (2022-06-04)

数*/{ case 1:sum0;break; case 2:sum31;break; case 3:sum59;break; case 4:sum90;break; case 5:sum120;break; case 6:sum151;break

嘻友喵叽
3年前 (2022-06-04)

m,i,k,h0,leap1;printf("\n");for(m101;m200;m++){ ksqrt(m+1);for(i2;ik;i++)if(m%i0){leap0;break;

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。