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范,并且可以直接 ...
随机推荐
- hdu 5087 Revenge of LIS II ( LIS ,第二长子序列)
链接:hdu 5087 题意:求第二大的最长升序子序列 分析:这里的第二大指的是,全部的递增子序列的长度(包含相等的), 从大到小排序后.排在第二的长度 cid=546" style=&qu ...
- java中 ++前后差别试题及静态变量一旦赋值不可改变
package javaTest; public class Increment { private static int k=0; public static void main(String[] ...
- quick-cocos2d-x教程10:实现血条效果。
血条是常见功能.能够通过一个血条背景和一个不断改变的血条宽度.来实现少血. 在MainScence.lua中,先改代码: function MainScene:ctor() local bg ...
- jquery获取input值的各种情况
jQuery获取多种input值的方法 获取input的checked值是否为true: 第一种: if($("input[name=item][value='val']").at ...
- web前端开发 代码规范 及注意事项
web前端开发 代码规范 及注意事项 外部命名规范 html .js .css文件名称命名规范 my_script.js my_camel_case_name.css my_index.html 路径 ...
- 在Eclipse中tomcat 内存配置
修改1: 在Eclipse中下面Servers双击Tomcat Server... 然后点击General InformAtion 下的Open launch configuration: 会弹出Ed ...
- [JS进阶] HTML5 之文件操作(file)
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/oscar999/article/details/37499743 前言 在 HTML 文档中 < ...
- WebService_使用三要素
一.Java中WebService规范 JAVA 中共有三种WebService 规范,分别是JAX-WS.JAX-RS.JAXM&SAAJ(废弃). 1.JAX-WS规范 JAX-WS 的全 ...
- 机器学习: KNN--python
今天介绍机器学习中比较常见的一种分类算法,K-NN,NN 就是 Nearest Neighbors, 也就是最近邻的意思,这是一种有监督的分类算法,给定一个 test sample, 计算这个 tes ...
- 【HDU 2167】 Pebbles
[题目链接] 点击打开链接 [算法] 状压DP 先搜出一行符合的情况,然后,f[i][j]表示第i行,状态为j,能够取得的最大值,DP即可 [代码] #include<bits/stdc++.h ...