链接

发个长长的模拟 这题要注意的地方挺多 -的个数 以及对齐的情况 全都注意好了 大数的加减乘就可以了

 #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(模拟)的更多相关文章

  1. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  2. 故障重现, JAVA进程内存不够时突然挂掉模拟

    背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...

  3. Python 爬虫模拟登陆知乎

    在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...

  4. HTML 事件(四) 模拟事件操作

    本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4.  ...

  5. 模拟AngularJS之依赖注入

    一.概述 AngularJS有一经典之处就是依赖注入,对于什么是依赖注入,熟悉spring的同学应该都非常了解了,但,对于前端而言,还是比较新颖的. 依赖注入,简而言之,就是解除硬编码,达到解偶的目的 ...

  6. webapp应用--模拟电子书翻页效果

    前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...

  7. javascript动画系列第一篇——模拟拖拽

    × 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...

  8. C++ 事件驱动型银行排队模拟

    最近重拾之前半途而废的C++,恰好看到了<C++ 实现银行排队服务模拟>,但是没有实验楼的会员,看不到具体的实现,正好用来作为练习. 模拟的是银行的排队叫号系统,所有顾客以先来后到的顺序在 ...

  9. MSYS2——Windows平台下模拟linux环境的搭建

    最近从MSYS1.0迁移到了MSYS2.0,简单讲,MSYS2.0功能更强大,其环境模拟更加符合linux.虽然本身来自cygwin,但其集成了pacman软件管理工具,很有linux范,并且可以直接 ...

随机推荐

  1. Spark应用远程调试

    本来想用Eclipse的.然而在网上找了一圈,发现大家都在说IntelliJ怎样怎样好.我也受到了鼓励,遂决定在这台破机器上鼓捣一次IntelliJ吧. Spark程序远程调试,就是将本地IDE连接到 ...

  2. C语言的结构体和 C++结构体的区别

     C语言的结构体和 C++结构体的区别 关于C++中声明结构体中需要使用构造器创建实例对象的语法: <C++的结构体构造方法的基本概念:结构体的构造方法需要和结构体的名字相同,并且无返回值,也不 ...

  3. 【iOS系列】-iOS中内存管理

    iOS中创建对象的步骤: 1,分配内存空间,存储对象 2,初始化成员变量 3,返回对象的指针地址 第一:非ARC机制: 1,对象在创建完成的同时,内部会自动创建一个引用计数器,是系统用来判断是否回收对 ...

  4. PyTorch 60 分钟入门教程:PyTorch 深度学习官方入门中文教程

    什么是 PyTorch? PyTorch 是一个基于 Python 的科学计算包,主要定位两类人群: NumPy 的替代品,可以利用 GPU 的性能进行计算. 深度学习研究平台拥有足够的灵活性和速度 ...

  5. VS2013如何调用别人发布的WebService程序

    这篇经验会告诉我们如何调用别人发布的WebService,并且需要注意的事项.现在就拿获取天气预报的接口举例,因为文中不允许有链接,所以在下文图中有WebService链接的地址. 工具/原料 VS2 ...

  6. Statement 与 PreparedStatement 区别

    Statement由方法createStatement()创建,该对象用于发送简单的SQL语句 PreparedStatement由方法prepareStatement()创建,该对象用于发送带有一个 ...

  7. js加减乘除丢失精度

    js加减乘除(学了那么久现在才注意到汗==!) /** ** 除法函数,用来得到精确的除法结果 ** 说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显.这个函数返回较为精 ...

  8. Jackson 框架的高阶应用

    Jackson 是当前用的比较广泛的,用来序列化和反序列化 json 的 Java 的开源框架.Jackson 社 区相对比较活跃,更新速度也比较快, 从 Github 中的统计来看,Jackson ...

  9. 使用linux内核hrtimer高精度定时器实现GPIO口模拟PWM,【原创】

    关键词:Android  linux hrtimer 蜂鸣器  等待队列 信号量 字符设备 平台信息:内核:linux3.4.39 系统:android/android5.1平台:S5P4418  作 ...

  10. 《Visual C++ 2010入门教程》系列三:关于C++的一些问题

    <Visual C++ 2010入门教程>系列三:关于C++的一些问题   这一回我自己都不知道应该写点什么好,或许今天的篇幅会比往常短很多.我说过,这不是C++的教程,因为我还没有那个能 ...