题目描述 数字整除
定理:把一个至少两位的正整数的个位数字去掉,再从余下的数中减去个位数的5倍。当且仅当差是17的倍数时,原数也是17的倍数 。
例如,34是17的倍数,因为3-20=-17是17的倍数;201不是17的倍数,因为20-5=15不是17的倍数。输入一个正整数n,你的任务是判断它是否是17的倍数。
输入
输入文件最多包含10组测试数据,每个数据占一行,仅包含一个正整数n(1<=n<=10100),表示待判断的正整数。n=0表示输入结束,你的程序不应当处理这一行。
输出
对于每组测试数据,输出一行,表示相应的n是否是17的倍数。1表示是,0表示否。
样例输入 Copy
<span style="background-color:#ffffff"><span style="color:#333333"><span style="color:#333333"><span style="background-color:#f5f5f5">34
201
2098765413
1717171717171717171717171717171717171717171717171718
0
</span></span></span></span>
样例输出 Copy
<span style="background-color:#ffffff"><span style="color:#333333"><span style="color:#333333"><span style="background-color:#f5f5f5">1
0
1
0</span></span></span></span>
#include<stdio.h>
int main()
{
int i;
long long int x,qian,ge,t;
for(i=1;i<=10;i++)
{
scanf("%lld",&x);
if(x==0)
{
return 0;
}else{
qian=x/10;
ge=x%10;
t=qian-5*ge;
if(t%17==0)
{
printf("1\n");
}else{
printf("0\n");
}
}
}
return 0;
}
这个没办法应对大整数
1717171717171717171717171717171717171717171717171718 这样的数字该怎么办呢
等我学数组了再看一下
有n个正整数,将其奇偶标签化。即奇数标记为1,偶数标记为0。
输入
输入由两行组成。
第一行是一个大于1且小于100的整数n。
第二行是n个空格分开的正整数,整数值均不超过10000。
输出
输出一行,格式如"[1,0,...0,1]",括号中逗号隔开的0或1标记对应输入整数的奇偶。
样例输入 Copy
6 1 2 3 4 5 6
样例输出 Copy
[1,0,1,0,1,0]
#include<stdio.h>
int main()
{
int n,i;
scanf("%d",&n);
int input[n];//定义一个数组
for(i=0;i<=n-1;i++)
{
scanf("%d",&input[i]);//for循环输入数组
}
printf("[");
for(i=0;i<=n-1;i++)//一个循环分成两个写 ,为了前面 能输出一个[
{
if(i>0){
printf(",");//巧妙的利用i只要输出一个数字之后就加上逗号
//最后一个数字输出后不进入循环就无法输出逗号
}
if(input[i]%2==0)
{
printf("0");
}else {
printf("1");
}
}
printf("]");
return 0;
}
在两个数字中间输入逗号,可以在循环里添加if语句,通过i的变化来巧妙达成!