西西软件园多重安全检测下载网站、值得信赖的软件下载站!
软件
软件
文章
搜索

首页编程开发VC|VC++ → 魔法数字Magic Number C语言代码

魔法数字Magic Number C语言代码

相关软件相关文章发表评论 来源:本站整理时间:2010/10/4 0:53:22字体大小:A-A+

作者:佚名点击:293次评论:0次标签: Magic

  • 类型:滤镜插件大小:54.0M语言:中文 评分:2.1
  • 标签:
立即下载

题目描述:
如果一个数(可能包含前导0)乘以2,如142857*2=285714,
依然由原来的数字组成的话,这样的数(142857)就叫Magic Number

输入:
多组测试数据,每组一行,每行是一个不大于1e10000整数(可能有前导0),
遇到EOF标志结束程序

输出:
判断这个数是不是Magic Number,是的话输出“Magic Number”
否则输出“Not Magic Number”

样例输入:
142857
0142857
857142
0588235294117647

样例输出:
Magic Number
Magic Number
Not Magic Number
Magic Number

难度:Very Easy

CODE:

#include <stdio.h>
#include <string.h>
#define MAX 10001
typedef struct {
int date[MAX];
int len;
}BigInt;
int magic(BigInt a,int m);
int main() {
char str[MAX];
BigInt a;
int i,len;
while ( scanf("%s",str) != EOF ) {
len = strlen(str);
for ( i = 0; i < len; i++ ) {
a.date[len-i-1] = str[i] - '0';
}
a.len = len;
if ( magic(a,2) ) {
printf("Magic Number\n");
} else {
printf("Not Magic Number\n");
}
}
return 0;
}
int magic(BigInt a,int m) {
int i,temp;
int carry = 0;
int s[10],e[10];
for( i = 0; i < 10; i++ ) {
s[i] = e[i] = 0;
}
for ( i = 0; i < a.len; i++ ) {
s[a.date[i]] ++;
}
for ( i = 0; i < a.len; i ++ ) {
temp = a.date[i] * m + carry;
e[temp%10] ++;
carry = temp / 10;
}
if ( carry ) {
e[carry] ++;
}
for ( i = 0; i < 10; i++ ) {
if ( s[i] != e[i] ) {
return 0;
}
}
return 1;
}

CODE1:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main() {
int a[10005],old[10],mulold[10];
memset(old,0,sizeof(old));
memset(mulold,0,sizeof(mulold));
char c;
int i=0,j,k,bit=0,number=0;
bool flag=true;
for (;scanf("%c",&c)!=EOF;i=0,bit=0,number=0,flag=true) {
//scanf("%c",&c);
while(c!='\n') {
/*if(i==0&&c=='0') {
while(c=='0')
scanf("%c",&c);
}
if(c=='\n')
break;*/
a[i]=c-'0';
old[c-'0']=1;
i++;
scanf("%c",&c);
}
//for(j=0;j<i;j++) printf("%d ",a[j]);
/*if(a[0]==0) {
printf("Magic Number \n");
flag=false;
}
else*/
for(j=0;j<i;j++) {
int tmp=a[i-1-j]*2+bit;
//printf("tmp:%d ",tmp);
if(j==i-1&&tmp>=10) {
if(old[tmp/10]==0)
{
printf("*Not Magic Number \n");
flag=false;
break;
}
mulold[tmp/10]=1;
}
if(old[tmp%10]==0)
{
printf("*Not Magic Number \n");
flag=false;
break;
}
mulold[tmp%10]=1;
bit=tmp/10;
}
//for(k=0;k<10;k++) {printf("%d ",old[k]);printf("%d\n",mulold[k]);}
if(flag) {
for(k=0;k<10;k++)
if(old[k]!=mulold[k]) {
printf("Not Magic Number \n");
break;
}
if(k==10)
printf("Magic Number \n");

}
memset(old,0,sizeof(old));
memset(mulold,0,sizeof(mulold));
}
return 0;
}

CODE2:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main() {
int a[10005],old[10],mulold[10];
memset(old,0,sizeof(old));
memset(mulold,0,sizeof(mulold));
char c;
int i=0,j,k,bit=0,number=0;
bool flag=true;
for (;scanf("%c",&c)!=EOF;i=0,bit=0,number=0,flag=true) {
//scanf("%c",&c);
while(c!='\n') {
/*if(i==0&&c=='0') {
while(c=='0')
scanf("%c",&c);
}
if(c=='\n')
break;*/
a[i]=c-'0';
old[c-'0']=1;
i++;
scanf("%c",&c);
}
//for(j=0;j<i;j++) printf("%d ",a[j]);
/*if(a[0]==0) {
printf("Magic Number \n");
flag=false;
}
else*/
for(j=0;j<i;j++) {
int tmp=a[i-1-j]*2+bit;
//printf("tmp:%d ",tmp);
if(j==i-1&&tmp>=10) {
if(old[tmp/10]==0)
{
printf("Not Magic Number \n");
flag=false;
break;
}
mulold[tmp/10]=1;
}
if(old[tmp%10]==0)
{
printf("*Not Magic Number \n");
flag=false;
break;
}
mulold[tmp%10]=1;
bit=tmp/10;
}
//for(k=0;k<10;k++) {printf("%d ",old[k]);printf("%d\n",mulold[k]);}
if(flag) {
for(k=0;k<10;k++)
if(old[k]!=mulold[k]) {
printf("Not Magic Number \n");
break;
}
if(k==10)
printf("Magic Number \n");

}
memset(old,0,sizeof(old));
memset(mulold,0,sizeof(mulold));
}
return 0;
}

    调色软件
    (16)调色软件
    色彩既是客观世界的反映,但又是主观世界的感受。某种色调一些人会棒为至尊宝典,另一些人可能则视为垃圾,这完全属于萝卜青菜,各有所爱的问题,但也反映了色彩既是客观存在又是主观感受这个事实。色彩搭配的问题确实不是一个简单的问题。这一代的设计师比上一代的设计师,所能运用的色彩工具多了许多。如今,我们能运用好计算机为我们提供的丰富色彩,看来不是很简单的事情。在专业的调色软件中,达芬奇调色系统被誉为后期制作的...更多>>
    AE插件大全
    (22)AE插件大全
    插件可以说是用户非常喜欢的,一款好的插件可以帮用户轻松解决问题,就像大家所熟知的插件,它可以产生各种各样的自然效果,像烟火闪光。也可以产生有机的和高科技风格的图形效果,它对于运动的图形设计是非常有用的。插件怎么安装插件有安装版和复制文件两种,安装版和复制版都放在下。也就是在你安装目录下这个文件夹里,启动时就自动检测插件了。...更多>>
    • AE超级特效插件(Red Giant Effects

      11-01 / 267.5M

      推荐理由:Red Giant Effects系列插件能为您的工作和创作提供超级自由的空间。其中包括了经典的卡通效果插件、灯光工厂
    • AE环形冲击波生成插件(YY_ShockRin

      11-01 / 87KB

      推荐理由:AE 环形冲击波生成插件 YY_ShockRing.aex 是一个功能完备的AE插件,它能创建出使圆环产生斜坡反射的特效,你
    • AE渐变特效插件(YY_Ramp+)

      11-01 / 91KB

      推荐理由:YY_Ramp+是一款运行在After Effects平台下的AE渐变特效插件,该插件支持After Effects CS6, CS5.5, CS5, CS
    • AE镜头畸变校正插件(Lens Distorti

      11-01 / 41KB

      推荐理由:Lens Distortion是一款运行在After Effects平台上的插件滤镜软件,因该插件的主要功能为校正镜头畸变影响而
    • AE水墨效果插件

      07-02 / 10.2M

      推荐理由:制作水墨画效果的插件,AE、PR均可作用(二者只选其一,假如在它们的插件目录中都安装的话,可能会有冲突)
    • AE调色插件(Magic Bullet Looks)2.

      05-31 / 10.7M

      推荐理由:该插件人性化的设计,为初学者提供了很多预设效果。该插件也是唯一的一款 可以单独完成最大限度模拟电影胶片

    相关评论

    阅读本文后您有什么感想? 已有人给出评价!

    • 8 喜欢喜欢
    • 3 顶
    • 1 难过难过
    • 5 囧
    • 3 围观围观
    • 2 无聊无聊

    热门评论

    最新评论

    第 1 楼 浙江台州台州职业技术学院 网友 客人 发表于: 2010/10/29 12:59:47

    支持( 0 ) 盖楼(回复)

    发表评论 查看所有评论(0)

    昵称:
    表情: 高兴 可 汗 我不要 害羞 好 下下下 送花 屎 亲亲
    字数: 0/500 (您的评论需要经过审核才能显示)