1076: 汇编语言

Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 34  Solved: 4
[Submit][Status][Web
Board
]

Description

Input

Output

Sample Input

2
3
MOV AX,2
MOV BX,3
ADD AX,BX
6
MOV AX,2
MOV BX,030H
MOV CX,11B
ADD AX,CX
ADD DL,CL
MUL DL

Sample Output

5 3 0 0
15 48 3 3

HINT

注意在 MOV 和 ADD 操作中,指令的两个操作对象的位数应当是一致的,即不会出现如 MOV AX,BL

或 ADD AL,0100H 这样错误的指令。

在初始状态下,四个通用寄存器中的数值均为 0。给定一系列的汇编指令,请输出按顺序执行完所

有指令后四个通用寄存器中的数值。

这题真的没啥好说。很无语....从省赛选拔赛开始到现在一直WA,直到找了老师要了后台数据(对自己真的无语了),发现两个问题:

1、给一个变量赋值时会先计算,再赋值,比如我原来代码的long long val = 655535 * 65535,首先计算右边的值,由于还没有赋值给val,因此范围仍然在int内,四十亿的数据直接把int给炸飞了,将溢出之后的结果-131071赋给了val,因此原本的输出出现了负数。

2、低八位和高八位的寄存器可以互相作用,比如将AL加或赋值给CH,之前的判断中以为只能是低位与低位操作,高位与高位操作。

大小号总计WA十余次(递归懵比.jpg,本垃圾错了.jpg)。
爆炸代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<set>
#include<map>
#include<sstream>
#include<algorithm>
#include<cmath>
#include<cstdlib>
using namespace std;
typedef long long LL;
struct poi
{
LL di;
LL gao;
};
inline void change(string &s)
{
for (LL i=0; i<(LL)s.size(); i++)
{
if(s[i]==',')
{
s[i]=' ';
}
}
}
inline LL sto(string s)
{
LL sum=0;
LL i;
LL len=(LL)s.size();
if(s[len-1]=='H'&&s[0]=='0')
{
for (i=0; i<len-1; i++)
{
if(s[i]>='A'&&s[i]<='Z')
sum=sum*16+(s[i]-'A'+10);
else if(s[i]>='a'&&s[i]<='z')
sum=sum*16+(s[i]-'a'+10);
else
sum=sum*16+(s[i]-'0');
}
}
else if(s[len-1]=='B')
{
for (i=0; i<len-1; i++)
sum=sum*2+(s[i]-'0');
}
else
{
for (i=0; i<len; i++)
{
sum=sum*10+(s[i]-'0');
}
}
return sum;
}
int main (void)
{
ios::sync_with_stdio(false);
LL t,n,i,j;
string op,one,two,s;
char c;
cin>>t;
while (t--)
{
cin>>n;
map<LL,poi>list;
list[0].di=list[0].gao=0;
list[1].di=list[1].gao=0;
list[2].di=list[2].gao=0;
list[3].di=list[3].gao=0;
cin.get();
for (i=0; i<n; i++)
{
getline(cin,s);
change(s);
istringstream sin(s);
sin>>op>>one;
if(op=="MOV")
{
sin>>two;
if(isdigit(two[0]))
{
LL val=sto(two);
if(one[1]=='H')
list[one[0]-'A'].gao=val;
else if(one[1]=='L')
list[one[0]-'A'].di=val;
else
{
list[one[0]-'A'].di=val%256;
list[one[0]-'A'].gao=val/256;
}
}
else
{
if(one[1]=='H')
{
if(two[1]=='H')
list[one[0]-'A'].gao=list[two[0]-'A'].gao;
else if(two[1]=='L')
list[one[0]-'A'].gao=list[two[0]-'A'].di;
}
else if(one[1]=='L')
{
if(two[1]=='H')
list[one[0]-'A'].di=list[two[0]-'A'].gao;
else if(two[1]=='L')
list[one[0]-'A'].di=list[two[0]-'A'].di;
}
else
{
list[one[0]-'A'].di=list[two[0]-'A'].di;
list[one[0]-'A'].gao=list[two[0]-'A'].gao;
}
}
}
else if(op=="ADD")
{
sin>>two;
if(isdigit(two[0]))
{
LL val=sto(two);
if(one[1]=='H')
list[one[0]-'A'].gao+=val;
else if(one[1]=='L')
list[one[0]-'A'].di+=val;
else
{
val=val+list[one[0]-'A'].gao*256+list[one[0]-'A'].di;
list[one[0]-'A'].di=val%256;
list[one[0]-'A'].gao=val/256;
}
}
else
{
if(two[1]=='L')
{
if(one[1]=='L')
list[one[0]-'A'].di+=list[two[0]-'A'].di;
else if(one[1]=='H')
list[one[0]-'A'].gao+=list[two[0]-'A'].di;
}
else if(two[1]=='H')
{
if(one[1]=='L')
list[one[0]-'A'].di+=list[two[0]-'A'].gao;
else if(one[1]=='H')
list[one[0]-'A'].gao+=list[two[0]-'A'].gao;
}
else
{
LL vall=list[two[0]-'A'].di+list[two[0]-'A'].gao*256+list[one[0]-'A'].di+list[one[0]-'A'].gao*256;
list[one[0]-'A'].di=vall%256;
list[one[0]-'A'].gao=vall/256;
}
}
}
else if(op=="MUL")
{
LL val;
if(one[1]=='L')
{
val=list[one[0]-'A'].di*list[0].di;
list[0].di=val%256;
list[0].gao=val/256;
}
else if(one[1]=='H')
{
val=list[one[0]-'A'].gao*list[0].di;
list[0].di=val%256;
list[0].gao=val/256;
}
else
{
LL v1=(list[0].gao*256+list[0].di)*(list[one[0]-'A'].gao*256+list[one[0]-'A'].di);
list[0].di=v1%65536%256;
list[0].gao=v1%65536/256;
list[3].di=v1/65536%256;
list[3].gao=v1/65536/256;
}
}
}
for (LL i=0; i<4; i++)
{
LL val=list[i].gao*256+list[i].di;
if(i!=3)
cout<<val<<" ";
else
cout<<val<<endl;
}
}
return 0;
}

ACM程序设计选修课——1076汇编语言(重定向+模拟)的更多相关文章

  1. ACM程序设计选修课——1041: XX's easy problem(神烦的多次字符串重定向处理)

    1041: XX's easy problem Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 41  Solved: 7 [Submit][Statu ...

  2. ACM程序设计选修课——1044: (ds:队列)打印队列(queue模拟)

    问题 A: (ds:队列)打印队列 时间限制: 1 Sec  内存限制: 128 MB 提交: 25  解决: 4 [提交][状态][讨论版] 题目描述 网络工程实验室只有一台打印机,它承担了非常繁重 ...

  3. ACM程序设计选修课——1057: Beautiful Garden(模拟+耐心调试)

    1057: Beautiful Garden Time Limit: 5 Sec  Memory Limit: 128 MB Submit: 25  Solved: 12 [Submit][Statu ...

  4. 第13届景驰-埃森哲杯广东工业大学ACM程序设计大赛 G 旋转矩阵 【模拟】

    链接:https://www.nowcoder.com/acm/contest/90/G 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536 ...

  5. ACM程序设计选修课——Problem D: (ds:树)合并果子(最优二叉树赫夫曼算法)

    Problem D: (ds:树)合并果子 Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 80  Solved: 4 [Submit][Status][ ...

  6. ACM程序设计选修课——Problem E:(ds:图)公路村村通(Prim)

    问题 E: (ds:图)公路村村通 时间限制: 1 Sec  内存限制: 128 MB 提交: 9  解决: 5 题目描述 现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本, ...

  7. ACM程序设计选修课——Problem F:(ds:图)旅游规划(优先队列+SPFA)

    问题 F: (ds:图)旅游规划 时间限制: 1 Sec  内存限制: 128 MB 提交: 14  解决: 4 题目描述 有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路 ...

  8. ACM程序设计选修课——Problem E:(ds:图)公路村村通(优先队列或sort+克鲁斯卡尔+并查集优化)

    畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  9. ACM程序设计选修课——1018: Common Subsequence(DP)

    问题 L: Common Subsequence 时间限制: 1 Sec  内存限制: 32 MB 提交: 70  解决: 40 [提交][状态][讨论版] 题目描述 A subsequence of ...

随机推荐

  1. 使用JDK自带的VisualVM进行Java程序的性能分析

    VisualVM是什么? VisualVM是JDK自带的一个用于Java程序性能分析的工具,JDK安装完毕后就有啦,在JDK安装目录的bin文件夹下能找到名称为jvisualvm.exe. 要使用Vi ...

  2. 组件的通信 :provide / inject 对象进入后,就等于不用props,然后内部对象,直接复制可以接受数组,属性不能直接复制,可以用Object.assgin覆盖对象,或者Vue的set 双向绑定数据

    组件的通信 :provide / inject 对象进入后,就等于不用props,然后内部对象,直接复制可以接受数组,属性不能直接复制,可以用Object.assgin覆盖对象,或者Vue的set 双 ...

  3. Memcached笔记之分布式算法

    1.根据余数进行分散:离散度高,但是增加或者移除服务器的时候,缓存充足的代价非常大.添加服务器后,余数就会产生巨变,这样就无法获取与保存时相同的服务器,从而音像缓存的命中率. 2.Consistent ...

  4. 使用FileSystemWatcher组件监视日志文件

    实现效果: 知识运用: FileSystemWatcher组件的Path属性 Filter属性 //要监视那些文件   默认为*.* Endinit方法 //结束在窗体上使用或有另一个组件使用的Fil ...

  5. 爬虫1_python2

    # -*- coding: UTF-8 -*- # python2爬虫 import urllib f = urllib.urlopen("http://www.itcast.cn/&quo ...

  6. Mybatis中关于OGNL表达式冲突

    注意设计表字段不能用bor  xor  and  band  eq  neq  lt  gt  lte  gte  shl  shr  ushr

  7. thinkphp 为什么访问路径错误,还可以访问

    在学习中访问入口文件,实际上应该访问public\index\index\   但其实也可以访问application.admin.controller\index,同样可以在网页下显示 原理:pub ...

  8. lua 使用正则表达式分割字符串

    function string_split(str, delimiter) if str == nil or str == '' or delimiter == nil then  return ni ...

  9. BZOJ-1833(数位DP)

    #include <bits/stdc++.h> using namespace std; typedef long long ll; ll a,b; int k[20]; ll dp[2 ...

  10. Maven配置项目依赖使用本地仓库的方法汇总

    Maven配置项目使用本地仓库有以下方式实现: 1.类似本地仓库,但是属于本地依赖,比如某个JAR包是引用第三方的,直接放在了项目的lib文件夹,那么此时可以如下配置项目的POM: <depen ...