A类(3):
- 计算所有因子之和:
int fun(int n)
{
int i,s=0;
for(i=2;i<n;i++)
if(n%i==0)
s+=i;
return s;
}
- 范围内找出能被特定值整除的数:
int fun(int x[], int e, int *sum)
{
int i,n=0, s=0;
for(i=0;i<N;i++)
{
if(x[i]%e==0)
n++;
else
s+=x[i];
}
*sum=s;
return n;
}
- 判断整数位数:
int fun(int n)
{
int bits=0;
while(n)
{
bits++;
n/=10;
}
return bits;
}
B类(2):
- 分离浮点型数的整数和小数:
void fun( double aa, int *x, double *y )
{
*x=(int)aa;
*y=aa-*x;
}
- 数值保留(两位):
float fun (float h )
{
int t;
t=(int)(h*1000+5)/10;
return (float)t/100.0;
}
C类(2):
- 四叶玫瑰:
int fun(int n, int result[])
{
int a,b,c,d,i,j=0;
for(i=1000;i<n;i++)
{
a=i%10;
b=i/10%10;
c=i/100%10;
d=i/1000;
if((a*a*a*a+b*b*b*b+c*c*c*c+d*d*d*d)==i)
result[j++]=i;
}
return j;
}
- 寻找特殊数:
struct BITS fun(int n)
{
struct BITS res;
/* 在这里将函数代码补充完整 */
res.m0 =n%10;
res.m1 =n/10%10;
res.m2 =n/100%10;
res.m3 =n/1000;
return res;
}
D类(2):
- 去数首位:
unsigned fun(unsigned w)
{
int n=1,j,s=1;
unsigned t;
t=w;
while(t>=10)
{
t/=10;
n++;
}
for(j=1;j<n;j++)
s*=10;
return w%s;
}
- 在四个数中组三位数(无重复):
int fun(int xxx[])
{
int i,j=0,a,b,c;
for(i=0;i<max;i++)
xxx[i]=0;//虽然此处感觉无用,但针对二级还是保留为妙。
for(i=123;i<=432;i++)
{
a=i%10;
b=i/10%10;
c=i/100;
if(a!=b&&b!=c&&a!=c&&a>=1&&a<=4&&b>=1&&b<=4&&c>=1&&c<=4)
{
printf("%4d",i);
xxx[j++]=i;
}
}
return j;
}