热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

就是乘法【NOIP2016提高A组模拟9.24】

题目这一天富爷又来找大头玩乘法游戏,然而不同于富爷的口算能力,大头只能列下了式子。第一题是432×5678:4325678-------3456302425922

题目

这一天富爷又来找大头玩乘法游戏,然而不同于富爷的口算能力,大头只能列下了式子。第一题是432 × 5678:
432
5678
-------
3456
3024
2592
2160
-------
2452896
作为环保主义者的大头,认为最后一行的答案一定不能有任何的前导空格,当然了,对于某些行来说前导空格不能省。但是,珍惜资源的大头,认为任何一行都不能有任何的后导空格。作为完美主义者的大头,认为每一行的长度都应该和最后的答案行匹配。
啊,对了,有时大头还会遇到富爷的坑,假如第二个乘数有一个位置是0的话,你会发现一个0就是对应行的答案,那就把0挪到下一行,并省去这一行~~举个例子,对于200001 × 90040:
200001
90040
-----------
8000040
180000900
-----------
18008090040

第四行的最右边是一个0,就是前一行(已省去)挪下来的,而第五行的最后两个0,则是由前两行(已省去)挪下来的。
最后一个坑,对于那些只有一行中间答案的,那么最后一部分也可以省略,
246 × 70:
246
70
-----
17220
在富爷压迫下的人民,你们准备好了吗?

样例输入:
输入文件有多组测试数据,每行包含两个正数a,b,保证a,b均不超过6位。
当a = b = 0时,该数据结束,该组并不需要输出。
432 5678
200001 90040
246 70
0 0

样例输出:
这里写图片描述


剖解题目

求两个不超过 107 的数的乘积,并按要求写出过程。


思路

模拟。
然而比赛时进位没有处理好,就挂了。


解法

模拟,可以用字符串,用数时记得开longlong。


代码

#include
#include
#include
#define ll long long
#define fo(i,a,b) for (int i=a;i<=b;i++)
#define down(i,a,b) for(int i=a;i>=b;i--)

using namespace std;

ll ans[15][15],x1,x2,x3;

int main()
{
//freopen("T.in","r",stdin);
// freopen("T.out","w",stdout);
int time=0;
scanf("%lld%lld",&x1,&x2);
while (x1&&x2) {
x3=x1*x2;
ll xx1=x1,xx2=x2,num3=0;
ll hg=x3,bn=0;
memset(ans,255,sizeof(ans));
while (hg) {
++num3;
hg/=10;
}
for(int pos=num3;xx1;pos--){
ans[1][pos]=xx1%10;
xx1/=10;
}
for(int pos=num3;xx2;pos--){
ans[2][pos]=xx2%10;
if (ans[2][pos]!=0) ++bn;
xx2/=10;
}
fo(i,1,num3) ans[3][i]=45;
xx2=x2;
int kh=4,kl=0;
while (xx2){
ll now=xx2%10,pos=0;
xx2/=10;
if (now){
xx1=x1;
while (xx1){
ll u=xx1%10; xx1/=10;
if (ans[kh][num3-pos-kl]==-1) ans[kh][num3-pos-kl]=0;
ans[kh][num3-pos-kl]=u*now+ans[kh][num3-pos-kl];
if (ans[kh][num3-pos-kl]/10!=0)
ans[kh][num3-pos-kl-1]=ans[kh][num3-pos-kl]/10;
ans[kh][num3-pos-kl]=ans[kh][num3-pos-kl]%10;
++pos;
}
++kh;
}
else ans[kh][num3-pos-kl]=0;
++kl;
}
if (bn!=1){
fo(i,1,num3) ans[kh][i]=45;
++kh;
for(int pos=num3;x3;pos--){
ans[kh][pos]=x3%10;
x3/=10;
}
} else --kh;
printf("Problem %d\n",++time);
fo(i,1,kh) {
fo(j,1,num3)
if (ans[i][j]==-1) printf(" ");
else if (ans[i][j]==45) printf("-");
else printf("%d",ans[i][j]);
printf("\n");
}
scanf("%d%d",&x1,&x2);
}
}

推荐阅读
  • DescriptionclickmeSolution套路的状压期望DP题。。。考虑倒退期望:设fi,jrolepresentationstyleposi ... [详细]
  • 题目描述Takuru是一名情报强者,所以他想利用他强大的情报搜集能力来当中间商赚差价。Takuru的计划是让Hinae帮他去市场上买一个商品,然后再以另一个价格卖掉它。Takur ... [详细]
  • JZOJ 1266. 玉米田
    1266.玉米田(cowfood.pasccpp)(FileIO):input:cowfood.inoutput:cowfood.outTimeLimits:1000msMemor ... [详细]
  • 796.[APIO2012]派遣在一个忍者的帮派里,一些忍者们被选中派遣给顾客,然后依据自己的工作获取报偿。在这个帮派里,有一名忍者被称之为Master。 ... [详细]
  • 题面传送门Solution看到什么最大值最小肯定二分啊。check直接跑一个二分图匹配就好了。orzztl!!!代码实现*mail:mle ... [详细]
  •   并查集是一种群众喜闻乐见的数据结构,其复杂度是数据结构中最奇葩的之一了,Tarjan证明其为阿克曼函数的反函数,在可以想象(不全面的解释啊)的范围内小于等于3。。。我们就把它当做O(1)吧。下面通 ... [详细]
  • 为什么即使Linux服务器的socket关闭,客户端仍能调用一次send函数?
    要弄清这个问题,首先需要知道调用send()发送数据时,发生了什么。当调用send()发送数据时,并不是直接将数据发送到网络中,而是先将待发送的数据放到socket发送缓冲区中,然 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Python如何调用类里面的方法
    本文介绍了在Python中调用同一个类中的方法需要加上self参数,并且规范写法要求每个函数的第一个参数都为self。同时还介绍了如何调用另一个类中的方法。详细内容请阅读剩余部分。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
author-avatar
渣渣
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有