只用加减或移位实现乘法

renzaijiang 2007-02-13 02:50:56
比如 int a=13 int b=10
如何做的 移位只能乘以2^n的数  
如何将b要分解成的两个2^n的数
...全文
370 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
renzaijiang 2007-02-14
  • 打赏
  • 举报
回复
除法
while(被除数位数>0)
{
余数接受最高位 (被除数左移1位);
试商;
被除数位数--;
保存余数,商;
renzaijiang 2007-02-13
  • 打赏
  • 举报
回复
c+=(a<<k);
用逻辑或通不过
renzaijiang 2007-02-13
  • 打赏
  • 举报
回复
已经解决了
int a=10;int b=4;int c=0;
int k=0;
for(int i=0;i<32;i++)
{
if(b&1==1)
c|=(a<<k);
b>>=1;
k++;
}
cout<<c;
taodm 2007-02-13
  • 打赏
  • 举报
回复
a*3 => (a << 1) + a
a*7 => (a << 2) + (a << 1) + a
是2进制,不是两个2^n

64,662

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧