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范,并且可以直接 ...
随机推荐
- 重载和重写在jvm运行中的区别(一)
1.重载(overload)方法 对重载方法的调用主要看静态类型,静态类型是什么类型,就调用什么类型的参数方法. 2.重写(override)方法 对重写方法的调用主要看实际类型.实际类型如果实现了该 ...
- 【.NET Core项目实战-统一认证平台】基于jackcao博客使用VSCode开发及感悟One搭建开发环境
原博客系列文章链接:https://www.cnblogs.com/jackcao/ 金焰的世界 感谢博主无私的奉献,感谢博主幼儿班的教学 基于jackcao博客使用VsCode开发及感悟One搭建开 ...
- 使用VLC搭建视频直播服务器
去年我们信息之夜我们进行过视频直播服务,当时我们使用了WMS(Windows Media Server)实现了这个服务,但是编码是微软的WMV,因而像iPhone/Android这样的智能手机无法观看 ...
- PADs 元器件PCB建库
直接看图就好了,上图! 有几点需要记住的: 如果没有datasheet的情况下,与焊盘相比,阻焊大0.1mm,钢网小0.1mm.或者阻焊大0.05mm,钢网等大,具体要看引脚的间距. 焊盘太大,比如1 ...
- YTU 2553: 谁是赢家
2553: 谁是赢家 时间限制: 1 Sec 内存限制: 128 MB 提交: 94 解决: 25 题目描述 某一天,hcbbt等一群弱菜去tamara巨巨家里一起玩了一个卡牌游戏.巨 巨家里有2 ...
- YTU 1004: 1、2、3、4、5...
1004: 1.2.3.4.5... 时间限制: 1000 Sec 内存限制: 64 MB 提交: 1275 解决: 343 题目描述 浙江工商大学校园里绿树成荫,环境非常舒适,因此也引来一批动物 ...
- linux下离线安装svn服务器并配置
一.下载相应的包 subversion-1.8.18.tar.gz 下载地址:http://subversion.apache.orgsqlite-autoconf-3190300.tar.gz ...
- I.MX6 AW-NB177NF wifi HAL 调试修改
/************************************************************************* * I.MX6 AW-NB177NF wifi H ...
- 解决axios IE11 Promise对象未定义
在你的项目中安装polyfill Babel Polyfill 按照官网方法安装并引入即可 http://blog.csdn.net/panyox/article/details/76377248
- ==和equals()的不同点
两者都可以用于对象的比较."=="用于比较两个对象的内存地址值(引用值)是否相等,equals()方法用于比较两个对象的内容是否一致. String str1 = new Stri ...