for(i=0;i<n;i++) printf("%4d",below[i]);}
2.请编写函数 fun,它的功能是:求出 1 到 1000 之内能被 7 或 11 整除、
但不能同时被 7 和 11 整除的所有整数并将它们放在 a 所指的数组中,
通过 n 返回这些数的个数。该题关键就是如何表示能被 7 或 11 整除,
但不能同时被 7 和 11 整除。用(i%7==0) || (i%11==0)来表示能被 7
或 11 整除,用 !((i%7==0) && (i%11==0))来表示不能同时被 7 和 11 整
除。
#include <conio.h>
#include <stdio.h>
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。由于要求的数不能是偶数故编程时
从 1 开始循环而步长为 2 这样正好保正 i 永远的奇数。这里也要注意
存放结果的数组 pp 的下标变化方式。
#include <conio.h>
#include <stdio.h>
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]);}
4.请编写一个函数 void fun(char *tt,int pp[]),统计在字符串中'a'
到'z'26 个字母各自出现的次数,并依次放在 pp 所指数组中。例如,当
输入字符串 abcdefgabcdeabc 后,程序的输出结果应该是:3 3 3 2 2 1
评论0
最新资源