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