C语言中关于数组的编程题~

C语言中关于数组的编程题~,第1张

main()

{const

int

n

=100;//最大可存数目

int

an;//注意方括号改成英文

int

i,n;

scanf("%d",&n);//几个数

n=n>n

n:n;

for(i

=0;

i<n;

i++)

if((scanf("%d",&ai)==eof);//输入项转换出错时

break;//结束输入

while(i--)

printf("%3d",

(a+n));//倒序输出数组

}

// 定义数组 nums

int[] nums = {25, 63, 12, 90, 44};

// 求出数组中的最大值

int max = nums[0];

for (int i = 1; i < numslength; i++) {

if (nums[i] > max) {

max = nums[i];

}

}

// 输出最大值

Systemoutprintln("最大值为:" + max);

在这段代码中,我们首先定义了一个整型数组 nums,并给数组赋初值为 25,63,12,90,44。然后,我们定义一个整型变量 max,并初始化为数组的第一个元素,即 25。接着,我们使用一个 for 循环遍历数组,依次比较数组中的每个元素,如果某个元素比当前的 max 值更大,则将 max 更新为该元素的值。最后,我们输出 max 的值,即数组中的最大值。

根据上面的代码,如果 nums 的值为 25,63,12,90,44,那么执行完上面的代码后,最大值为 90。

#include <stdioh>

#include <stdlibh>

#include <stringh>

int main(void)

{

int array;

int n,i,j,z,s=0,q=0;

int result[10]={0}; //存放众数

printf("请输入数组元素数量\r\n");

printf("n=");

scanf("%d",&n);

array=(int )malloc(nsizeof(int));

printf("请输入数组元素\r\n");

printf("array=");

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

{

scanf("%d",&array[i]);

}

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

{

z=0;

for(j=i;j<n;j++) //计数出当前数据出现的次数

{

if(array[i]==array[j])

{

z++;

}

}

printf("z=%d\r\n",z);

if(z>=n/2) //如果当前元素的数量超过了数组大小的一半不用往下分析了

{

result[q]=array[i];

break;

}

else if(z>s)

{

memset(result,0,10);

q=0;

result[q]=array[i];

s=z;

}

else if(z==s)

{

result[++q]=array[i];

}

}

printf("Sample Output:\r\n");

if(((q+1)s!=n)&&(q<5)) //按理来说10个数据众数应该不会超过4个,而前半部分避免了出现的次数相同

{

for(j=0;j<=q;j++) //打印出结果

{

printf("%d\r\n",result[j]);

}

}

else //如果没有就输出一个NO

printf("NO\r\n");

free(array);

return 0;

}

06年南开上机题

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<mm;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=10, t=10;

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

{

t=t+i;

s=s+1/t;

}

return s;

}

9: 第9题 编写一个函数fun,它的功能是:根据以下公式求p的值,结果由函数值带回。M与n为两个正整数,且要求m>n。 p=m!/n!(m-n)!

答案:float fun(int m, int n)

{

float p,t=10;

int I;

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

t=tI;

p=t;

for(t=10,i=1;i<=n;i++)

t=tI;

p=p/t;

for(t=10,i=1;i<=m-n;i++)

t=tI;

p=p/t;

return p;

}

10: 第10题 编写函数fun,它的功能是:利用以下的简单迭代方法求方程cos(x)-x=0的一个实根。

迭代步骤如下:(1)取x1初值为00; (2)x0=x1,把x1的值赋各x0;

(3)x1=cos(x0),求出一个新的x1;

(4)若x0-x1的绝对值小于0000001,则执行步骤(5),否则执行步骤(2);

(5)所求x1就是方程cos(x)-x=0的一个实根,作为函数值返回。

程序将输出root=0739085。

答案:float fun()

{

float x1=00,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=00;

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(t>10)

{

if(t/10)

p=t%10;

s=s+ps1;

s1=s110;

t=t/10;

}

return s;

}

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

答案:float fun(float h)

{

long t;

float s;

h=h1000;

t=(h+5)/10;

s=(float)t/1000;

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;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: 第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->s>max)

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的值(要求满足精度00005,即某项小于00005时停止迭代):

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)

程序运行后,如果输入精度00005,则程序输出为314…。

答案:double fun(double eps)

{

double s;

float n,t,pi;

t=1;pi=0;n=10;s=10;

while((fabs(s))>=eps)

{

pi+=s;

t=n/(2n+1);

s=t;

n++;

}

pi=pi2;

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==0&&s[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!=0&&s[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(k>n)

{

while (p&&p<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]s>max)

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=00;

int i:

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

av+=p->s[i];

av/=N;

p->ave=av;

}

以上就是关于C语言中关于数组的编程题~全部的内容,包括:C语言中关于数组的编程题~、编程题数组nums,并给数组赋值为25,63,12,90,44,求出数组中的最大值、C语言的数组编程题,求大神解答等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9488404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存