sdut1642Simple Arithmetics(模拟)
发个长长的模拟 这题要注意的地方挺多 -的个数 以及对齐的情况 全都注意好了 大数的加减乘就可以了
#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<stdlib.h>
#include<vector>
#include<cmath>
#include<queue>
using namespace std;
#define N 510
char s1[N],s2[N];
int s[N][N*],o[N];
int main()
{
int t,i,j,k1,k2,len;
char c,tc;
scanf("%d",&t);
getchar();
while(t--)
{
len = ;k1=;
for(;;)
{
scanf("%c",&c);
if(c=='+'||c=='-'||c=='*')
{
tc = c;
s1[k1] = '\0';
break;
}
s1[k1++] = c;
}
gets(s2);
k2 = strlen(s2);
for(i = ; i <= k2; i++)
for(j = ; j <= k2+k1+ ; j++)
s[i][j] = ;
for(i = ; i <= k2 ; i++)
o[i] = ;
if(tc=='+')
{
i = k1-,j=k2-;
int g = ;
while(i>=&&j>=)
{
int ko = s[][g]+s1[i--]-''+s2[j--]-'';
s[][g+] = ko/;
s[][g++] = ko%;
}
while(i>=)
{
int ko = s[][g]+s1[i--]-'';
s[][g+] = ko/;
s[][g++] = ko%;
}
while(j>=)
{
int ko = s[][g]+s2[j--]-'';
s[][g+] = ko/;
s[][g++] = ko%;
}
g++;
while(s[][g]==&&g>) g--;
int dd = max(g+,max(k1,k2+));
for(i = ; i <= dd-k1 ; i++) printf(" ");
printf("%s\n",s1);
for(i = ; i <= dd--k2 ; i++) printf(" ");
printf("%c%s\n",tc,s2);
for(i = ; i <= dd-max(k2+,g+) ; i++) printf(" ");
for(i = ; i <= max(k2+,g+) ; i++)
printf("-");
puts("");
for(i = ; i <= dd--g ; i++) printf(" ");
for(i = g ; i >= ; i--)
printf("%d",s[][i]);
puts("");
}
else if(tc=='-')
{
i = k1-,j=k2-;
int g = ;
while(i>=&&j>=)
{
int ko = s[][g]+s1[i]-s2[j];
if(ko<)
{
ko+=;s[][g+]--;
}
s[][g++] = ko;i--;j--;
}
while(i>=)
{
int ko = s[][g]+s1[i]-'';
if(ko<)
{
ko+=;s[][g+]--;
}
s[][g++] = ko;i--;
}
while(s[][g]==&&g>) g--;
int dd = max(k1,k2+);
for(i = ; i <= dd-k1 ; i++) printf(" ");
printf("%s\n",s1);
for(i = ; i <= dd--k2 ; i++) printf(" ");
printf("%c%s\n",tc,s2);
for(i = ; i <= dd-max(k2+,g+) ; i++) printf(" ");
for(i = ; i <= max(k2+,g+) ; i++) printf("-");
puts("");
for(i = ; i <= dd--g ; i++) printf(" ");
for(i = g ; i >= ; i--)
printf("%d",s[][i]);
puts("");
}
else
{
for(i = k2- ; i >= ; i--)
{
o[i] = k2--i;
for(j = k1- ; j >= ; j--)
{
int ko = s[i][o[i]]+(s2[i]-'')*(s1[j]-'');
s[i][o[i]+] = ko/;
s[i][o[i]++] = ko%;
}
while(s[i][o[i]]==&&o[i]>(k2--i)) o[i]--;
for(j = ; j <= max(o[k2],o[i]) ; j++)
{
int ko = s[k2][j]+s[i][j];
s[k2][j] = ko%;
s[k2][j+] += ko/;
}
o[k2] = max(o[k2],o[i]);
if(s[k2][o[k2]+]) o[k2]++;
}
while(s[k2][o[k2]]==&&o[k2]>) o[k2]--;
int dd = max(max(k1,k2+),o[k2]+);
int td = max(k2+,o[k2-]+);
for(i = ; i <= dd-k1 ; i++) printf(" ");
printf("%s\n",s1);
for(i = ; i <= dd-k2- ; i++) printf(" ");
printf("%c%s\n",tc,s2);
for(i = ; i <= dd-td ; i++) printf(" ");
for(i = ; i <= td ; i++)
printf("-");puts("");
for(i = k2- ; i >= ; i--)
{
for(j = ; j < dd-o[i] ; j++) printf(" ");
for(j = o[i] ; j >= k2-i- ; j--) printf("%d",s[i][j]);
puts("");
}
if(k2>)
{
for(i = ; i < dd-o[k2] ; i++) printf(" ");
for(i = ; i <= o[k2]+ ; i++)
printf("-");puts("");
for(i = ; i < dd-o[k2] ; i++) printf(" ");
for(i = o[k2] ; i >= ; i--)
printf("%d",s[k2][i]);
puts("");
}
}
puts("");
}
return ;
} /**************************************
Problem id : SDUT OJ 1642
User name : shang
Result : Accepted
Take Memory : 912K
Take Time : 160MS
Submit Time : 2014-02-15 20:53:30
**************************************/
sdut1642Simple Arithmetics(模拟)的更多相关文章
- App开发:模拟服务器数据接口 - MockApi
为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...
- 故障重现, JAVA进程内存不够时突然挂掉模拟
背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...
- Python 爬虫模拟登陆知乎
在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...
- HTML 事件(四) 模拟事件操作
本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4. ...
- 模拟AngularJS之依赖注入
一.概述 AngularJS有一经典之处就是依赖注入,对于什么是依赖注入,熟悉spring的同学应该都非常了解了,但,对于前端而言,还是比较新颖的. 依赖注入,简而言之,就是解除硬编码,达到解偶的目的 ...
- webapp应用--模拟电子书翻页效果
前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...
- javascript动画系列第一篇——模拟拖拽
× 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...
- C++ 事件驱动型银行排队模拟
最近重拾之前半途而废的C++,恰好看到了<C++ 实现银行排队服务模拟>,但是没有实验楼的会员,看不到具体的实现,正好用来作为练习. 模拟的是银行的排队叫号系统,所有顾客以先来后到的顺序在 ...
- MSYS2——Windows平台下模拟linux环境的搭建
最近从MSYS1.0迁移到了MSYS2.0,简单讲,MSYS2.0功能更强大,其环境模拟更加符合linux.虽然本身来自cygwin,但其集成了pacman软件管理工具,很有linux范,并且可以直接 ...
随机推荐
- 【Mongodb教程 第一课 补加课1 】windows7 下安装mongodb 开启关闭服务
mongodb在2.2版本开始就不支持windows xp了(我想现在用xp的应该也是带着情怀的一部分人吧,我只是一个工匠而已),windows下server8 R2,64位,32位,只是32位只支持 ...
- ==和equals的差别
== 和 Equals 的差别 1. == 是一个运算符. 2.Equals则是string对象的方法.能够.(点)出来. 我们比較无非就是这两种 1.基本数据类型比較 2.引用对象比較 1.基本数据 ...
- shell操作Hbase
status:查询集群的一些状态 hbase(main):002:0> status1 active master, 0 backup masters, 1 servers, 0 dead, 3 ...
- 02-Swift学习笔记-元组类型
02-Swift学习笔记-元组类型 元组类型由N个任意类型的数据组成(N>=0) 元组类型的数据称为"元素" eg var size = (x:100 , y:100) si ...
- aspx后台引用不到服务器控件
从其他地方拷贝的页面到自己的项目,后台CS代码引用hidden时,提示找不到,百度,发现可能是网站项目和Web应用程序的区别,右键aspx转化为Web应用程序即可.
- docker大全集
1,什么是docker docker 最初是dotCloud公司创始人 Solomon Hykes 在法国期间发起的一个公司内部醒目,于 2013年 3 月以 Apache 2.0 授权协议开源, 主 ...
- java反射(2)+Class.forName( )
在上一篇文章中说说java反射(1)我们已经了解了反射的基本概念以及它的原理,但是我们知道反射只能能用它来做些什么呢? 其实在我们很多已经很熟的框架中都有它的身影,例如Hibernate框架中的关联映 ...
- 怎样快速刪除Word中超链接?
有时我们从网上down了一些资料,存到Word文档里,会发现一些文字和图片带有超链接.这其实是Word自动修改功能引起的麻烦,那么,有什么办法可以把这些超链接快速批量删掉吗? 步骤/方法 1 按键盘上 ...
- Dos下同时执行多条命令简化操作
起因,要查询8080端口被哪些程序占用了,但是直接在cmd netstat –ano 的话 一下子一大把数据出来了不利于查找, 于是就想起dos下可以同时指向多条命令,如是写下如下命令: netsta ...
- Jackson 框架的高阶应用
Jackson 是当前用的比较广泛的,用来序列化和反序列化 json 的 Java 的开源框架.Jackson 社 区相对比较活跃,更新速度也比较快, 从 Github 中的统计来看,Jackson ...