判断一个数n能否同时被3和5整除。用自然语言和传统流程图表示求解的算法
展开全部
被3整除的数,各个数字和为3倍数。
被5整除的数,末位数字为0或5。
同时被3和5整除的数,各个数字和为3倍数且末位数字为0或5。
算法:
1、判断是否为3倍数
————把n拆开
————各数字相加除以3
————余数==0?
————是,转下一步;否,退出NO
2、判断末位数字是否为0或5
————末位数字==0或==5?
————是,退出YES;否,退出NO
或
1、判断是否为15倍数
————n对15取余
————余数==0?
————是,退出YES;否,退出NO
程序:
#include
void main()
{
int i,m,k=10,s=0;
int a[10];
printf("输入一个正整数:");
scanf("%d",&m);
a[0]=0;
for(i=1;i
推荐于2017-11-26 · 知道合伙人IT服务行家
关注
展开全部
被3整除的数,各个数字和为3倍数。
被5整除的数,末位数字为0或5。
==>同时被3和5整除的数,各个数字和为3倍数且末位数字为0或5。
或者更简单些,能被15整除。
算法:
1、判断是否为3倍数
————把n拆开
————各数字相加除以3
————余数==0?
————是,转下一步;否,退出NO
2、判断末位数字是否为0或5
————末位数字==0或==5?
————是,退出YES;否,退出NO
或
1、判断是否为15倍数
————n对15取余
————余数==0?
————是,退出YES;否,退出NO
程序:
#include<stdio.h>
void main()
{
int i,m,k=10,s=0;
int a[10];
printf("输入一个正整数:");
scanf("%d",&m);
a[0]=0;
for(i=1;i<10;i++)
{a[i]=(m-s)%k;k*=10;s+=a[i];}
if(s%3==0)
{if(a[1]==0||a[1]==5)printf("\nm能同时被3和5整除\n");
else printf("\nm不能同时被3和5整除\n");
}
else printf("\nm不能同时被3和5整除\n");
}
被5整除的数,末位数字为0或5。
==>同时被3和5整除的数,各个数字和为3倍数且末位数字为0或5。
或者更简单些,能被15整除。
算法:
1、判断是否为3倍数
————把n拆开
————各数字相加除以3
————余数==0?
————是,转下一步;否,退出NO
2、判断末位数字是否为0或5
————末位数字==0或==5?
————是,退出YES;否,退出NO
或
1、判断是否为15倍数
————n对15取余
————余数==0?
————是,退出YES;否,退出NO
程序:
#include<stdio.h>
void main()
{
int i,m,k=10,s=0;
int a[10];
printf("输入一个正整数:");
scanf("%d",&m);
a[0]=0;
for(i=1;i<10;i++)
{a[i]=(m-s)%k;k*=10;s+=a[i];}
if(s%3==0)
{if(a[1]==0||a[1]==5)printf("\nm能同时被3和5整除\n");
else printf("\nm不能同时被3和5整除\n");
}
else printf("\nm不能同时被3和5整除\n");
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
被3整除的数,各个数字和为3倍数。
被5整除的数,末位数字为0或5。
==>同时被3和5整除的数,各个数字和为3倍数且末位数字为0或5。
或者更简单些,能被15整除。
算法:
1、判断是否为3倍数
————把n拆开
————各数字相加除以3
————余数==0?
————是,转下一步;否,退出NO
2、判断末位数字是否为0或5
————末位数字==0或==5?
————是,退出YES;否,退出NO
或
1、判断是否为15倍数
————n对15取余
————余数==0?
————是,退出YES;否,退出NO
程序:
#include<stdio.h>
void main()
{
int i,m,k=10,s=0;
int a[10];
printf("输入一个正整数:");
scanf("%d",&m);
a[0]=0;
for(i=1;i<10;i++)
{a[i]=(m-s)%k;k*=10;s+=a[i];}
if(s%3==0)
{if(a[1]==0||a[1]==5)printf("\nm能同时被3和5整除\n");
else printf("\nm不能同时被3和5整除\n");
}
else printf("\nm不能同时被3和5整除\n");
}
被5整除的数,末位数字为0或5。
==>同时被3和5整除的数,各个数字和为3倍数且末位数字为0或5。
或者更简单些,能被15整除。
算法:
1、判断是否为3倍数
————把n拆开
————各数字相加除以3
————余数==0?
————是,转下一步;否,退出NO
2、判断末位数字是否为0或5
————末位数字==0或==5?
————是,退出YES;否,退出NO
或
1、判断是否为15倍数
————n对15取余
————余数==0?
————是,退出YES;否,退出NO
程序:
#include<stdio.h>
void main()
{
int i,m,k=10,s=0;
int a[10];
printf("输入一个正整数:");
scanf("%d",&m);
a[0]=0;
for(i=1;i<10;i++)
{a[i]=(m-s)%k;k*=10;s+=a[i];}
if(s%3==0)
{if(a[1]==0||a[1]==5)printf("\nm能同时被3和5整除\n");
else printf("\nm不能同时被3和5整除\n");
}
else printf("\nm不能同时被3和5整除\n");
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询