链接

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

 #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. leetcode ----Trie/stack专题

    一:Implement Trie (Prefix Tree) 题目: Implement a trie with insert, search, and startsWith methods. Not ...

  2. Echarts 的样例

    jsp页面: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8 ...

  3. 【转】SQL中的取整函数FLOOR、ROUND、CEIL、TRUNC、SIGN

    --------------------------------------------------------------------------1 trunc(value,precision)按精 ...

  4. 深入浅出 - Android系统移植与平台开发(十二)- Android JNI机制

    第五章.JNI机制 4.1 JNI概述 由前面基础知识可知,Android的应用层由Java语言编写,Framework框架层则是由Java代码与C/C++语言实现,之所以由两种不同的语言组合开发框架 ...

  5. break return continue

    1.return 语句的作用 (1) return 从当前的方法中退出,返回到该调用的方法的语句处,继续执行 (2) return 返回一个值给调用该方法的语句,返回值的数据类型必须与方法的声明中的返 ...

  6. hdu 2059 龟兔赛跑 (dp)

    /* 把起点和终点比作加油站,那总共同拥有n+2个加油站了, 每次都求出从第0个到第j个加油站(j<i)分别在加满油的情况下到第i个加油站的最短时间dp[i], 终于的dp[n+1]就是最优解了 ...

  7. mongo13----application set与分片结合

    replation set配合分片 打开3台服务器,B服务器()放configserv, C,D服务器(203.204)放置复制集 .203和192.168.1.204分别运行之前的sh start. ...

  8. 高清摄像头MIPI CSI2接口浅解【转】

    本文转载自:http://blog.csdn.net/u012075739/article/details/44672435 MIPI摄像头常见于手机.平板中,支持500万像素以上高清分辨率.它的全称 ...

  9. YTU 2953: A代码填充--学画画

    2953: A代码填充--学画画 时间限制: 1 Sec  内存限制: 128 MB 提交: 62  解决: 52 题目描述 最近小平迷上了画画,经过琨姐的指导,他学会了RGB色彩的混合方法.对于两种 ...

  10. 使用JSTL 对在页面上对 0,0,1 的分割处理 forTokens

    使用JSTL 对在页面上对 0,0,1 的分割处理 <tr onmouseover="currentcolor=this.style.backgroundColor;this.styl ...