(一道ACM题)好吧,我承认我C语言没有学多久,帮我看下哪儿错了,谢!
题目:Description数字黑洞,指的是某种运算,这种运算一般限定从某些整数出发,反复迭代后结果必然落入一个点或若干点。比如123数字黑洞和495数字黑洞,今天我们只...
题目:
Description
数字黑洞,指的是某种运算,这种运算一般限定从某些整数出发,反复迭代后结果必然落入一个点或若干点。比如123数字黑洞和495数字黑洞,今天我们只看123数字黑洞。任意整数a,如果它的偶数位的个数为b,奇数位的个数为c,b和c的和为d,那么定义运算@:@a = bcd。比如 @12 = 112,@2674829 = 527,@647382 = 426
那么123数字黑洞可以描述为:对于任意整数a,有
While(a != 123)a = @a;
这个循环可以结束。比如整数274829
@274829 = 426
@426 = 303
@303 = 123
可见,274829经过三次变换变成了123,现在,给你一个整数a,你知道它要经过几次变换才能变成123吗?
Input
输入包含多个测试实例,以EOF结束,每个测试实例仅包含一个整数a,(0<=a<=10000000)。
Output
输出整数a变成123需要经过的步数。每组实例占一行。
Sample Input
274829
Sample Output
3
我的代码:
#include"stdio.h"
int main()
{
long int n,a,b,c,y;
while(scanf("%d",&n)!=EOF)
{
y=0;
while(n!=123)
{
y++;
a=b=0;
do
{
if((n%10)%2==0)
a++;
else
b++;
n/=10;
}
while(n!=0);
c=a+b;
if(c>=10)
n=a*1000+b*100+c;
else
n=a*100+b*10+c;
}
printf("%d\n",y);
}
return 0;
} 展开
Description
数字黑洞,指的是某种运算,这种运算一般限定从某些整数出发,反复迭代后结果必然落入一个点或若干点。比如123数字黑洞和495数字黑洞,今天我们只看123数字黑洞。任意整数a,如果它的偶数位的个数为b,奇数位的个数为c,b和c的和为d,那么定义运算@:@a = bcd。比如 @12 = 112,@2674829 = 527,@647382 = 426
那么123数字黑洞可以描述为:对于任意整数a,有
While(a != 123)a = @a;
这个循环可以结束。比如整数274829
@274829 = 426
@426 = 303
@303 = 123
可见,274829经过三次变换变成了123,现在,给你一个整数a,你知道它要经过几次变换才能变成123吗?
Input
输入包含多个测试实例,以EOF结束,每个测试实例仅包含一个整数a,(0<=a<=10000000)。
Output
输出整数a变成123需要经过的步数。每组实例占一行。
Sample Input
274829
Sample Output
3
我的代码:
#include"stdio.h"
int main()
{
long int n,a,b,c,y;
while(scanf("%d",&n)!=EOF)
{
y=0;
while(n!=123)
{
y++;
a=b=0;
do
{
if((n%10)%2==0)
a++;
else
b++;
n/=10;
}
while(n!=0);
c=a+b;
if(c>=10)
n=a*1000+b*100+c;
else
n=a*100+b*10+c;
}
printf("%d\n",y);
}
return 0;
} 展开
3个回答
展开全部
#include <stdio.h>
int main()
{
long a,b,c,d,n;
while(scanf("%d",&a)!=EOF)
{
n=0;
while(a!=123)
{
b=c=d=0;
while(a)
{
if(a%2) c++;
a/=10;
d++;
}
b=d-c;
a=100*b+10*c+d;
n++;
}
printf("%d\n",n);
}
return 0;
}
int main()
{
long a,b,c,d,n;
while(scanf("%d",&a)!=EOF)
{
n=0;
while(a!=123)
{
b=c=d=0;
while(a)
{
if(a%2) c++;
a/=10;
d++;
}
b=d-c;
a=100*b+10*c+d;
n++;
}
printf("%d\n",n);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int h(long) ;
int main(void)
{
long n;
int count=0;
clrscr();
printf("Please input the shuju:");
if((scanf("%ld",&n))==EOF)
{
printf("error");
exit(1);
}
while(h(n)!=123)
{
printf("%d\n",h(n));
count++;
n=h(n);
}
printf("%d\n",h(n));
printf("%d",++count) ;
getch();
}
int h(long n)
{
long iz=1,iy;
int b=0,c=0;
while(iz != 0)
{
iz=n/10;
iy=n%10;;
if((iy%2)==0)
b++;
else
c++;
n=iz;
}
return b*100+c*10+b+c;
}
int h(long) ;
int main(void)
{
long n;
int count=0;
clrscr();
printf("Please input the shuju:");
if((scanf("%ld",&n))==EOF)
{
printf("error");
exit(1);
}
while(h(n)!=123)
{
printf("%d\n",h(n));
count++;
n=h(n);
}
printf("%d\n",h(n));
printf("%d",++count) ;
getch();
}
int h(long n)
{
long iz=1,iy;
int b=0,c=0;
while(iz != 0)
{
iz=n/10;
iy=n%10;;
if((iy%2)==0)
b++;
else
c++;
n=iz;
}
return b*100+c*10+b+c;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我跑的是正确的啊。。。你是那种错误?tl还是pe?
追问
就是自己运行正确,可是提交给网上的系统后说是错的,才问的——
追答
系统提示哪种错误?
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询