编写程序完成以下功能:输出小于1000的自然数中,能被11整除且各位数字之和为13的数。要求用如下函数判断一个整数是否能被11整除且各位数字之和是否为13:
void fun(int,int&,int *); /* 第1个参数传递要判断的数,第2个参数通过引用类型变量带回该数是否是11的倍数(是为1,不是为0),第3个参数通过指针类型变量带回该数各位数字之和*/
在主函数中调用上述函数,按每行5个的形式输出满足条件的数,并输出满足条件数的个数。
#include <iostream>
using namespace std;
void fun(int,int&,int *); /* 第1个参数传递要判断的数,第2个参数通过引用类型变量带回该数是否是11的倍数(是为1,不是为0),第3个参数通过指针类型变量带回该数各位数字之和*/
int main()
{
int i,cnt = 0;
int sum = 0,b;
for (i=1;i<1000;i++)
{
fun(i,b,&sum);
if(b && sum%13==0)
{
cnt++;
cout << i << " ";
if(cnt%5==0)
cout << endl;
}
}
return 0;
}
void fun(int n,int& b,int *sum)
{
int t = n;
int s = 0;
if(n%11 == 0) b=1;
else b = 0;
while(t)
{
s += t%10;
t/=10;
}
*sum = s;
}
用不断求余得到各位数,计算其总和判断是否为13