这个的解法很清晰,但是实在是太长了,后面会优化或者采用更加简洁的写法的
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int r=0;
struct bign
{
int d[1000];
int len;
bign()
{
memset(d,0,sizeof(d));
len=0;
}
};
bign change(char s[])
{
bign a;
a.len=strlen(s);
for (int i=0;i<a.len;i++)
{
a.d[i]=s[a.len-i-1]-'0';
}
return a;
}
void print(bign a)
{
for (int i=a.len-1;i>=0;i--)
{
printf("%d",a.d[i]);
}
}
bign multi(bign a)
{
bign c;
int carry=0;
for (int i=0;i<a.len;i++)
{
carry=a.d[i]*2+carry;
c.d[c.len++]=carry%10;
carry=carry/10;
}
while (carry!=0)
{
c.d[c.len++]=carry%10;
carry/=10;
}
return c;
}
int main()
{
char s[1000];
scanf("%s",s);
bign a=change(s);
int hashtable[10]={0};
for (int i=0;i<a.len;i++)
{
hashtable[a.d[i]]++;
}
bign b=multi(a);
if(b.len!=a.len)
{
printf("No\n");
}
else
{
int i;
for ( i=0;i<a.len;i++)
{
if(hashtable[b.d[i]]!=0)
{
hashtable[b.d[i]]--;
}
else
{
printf("No\n");
break;
}
}
if(i==a.len)
printf("Yes\n");
}
print(b);
}
本文介绍了一种使用C++实现的大数乘法算法,通过位运算将字符串形式的大数转换为数值进行处理,再将结果转换回字符串输出。算法首先定义了一个大数结构,用于存储大数并初始化。然后实现了将字符串转换为大数结构的函数,以及将大数结构打印为字符串的函数。接着,详细介绍了大数乘以2的算法,该算法逐位进行乘法和进位处理,直到所有位都被处理完毕。最后,通过一个主函数演示了如何使用这些函数来判断一个大数乘以2后的结果是否仍保持原有的数字频率。
6579

被折叠的 条评论
为什么被折叠?



