博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 5083 Instruction (稍比较复杂的模拟题)
阅读量:5331 次
发布时间:2019-06-14

本文共 1492 字,大约阅读时间需要 4 分钟。

题意:

二进制指令转汇编指令,汇编指令转二进制指令。

 

思路:

额,条理分好,想全,思维不能乱。

 

代码:

int findyu(char yu[50],char c){    int l=strlen(yu);    rep(i,0,l-1) if(c==yu[i]) return i;}int calc(char t[50],int x,int k){    int res=0;    rep(i,x,x+k-1) res*=10, res+=(t[i]-'0');    return res;}int calc2(char t[50]){    int l=strlen(t);    int res=0;    rep(i,0,l-1) res*=2, res+=(t[i]-'0');    return res;}void print(int x){    int t1[10];    int c=0;    rep(i,0,4){        t1[++c]=(x&1);        x>>=1;    }    rep2(i,c,1) printf("%d",t1[i]);}int main(){    //freopen("test.in","r", stdin);    int kind;    map
mp1; mp1["ADD"]="000001"; mp1["SUB"]="000010"; mp1["DIV"]="000011"; mp1["MUL"]="000100"; mp1["MOVE"]="000101"; mp1["SET"]="000110"; map
mp2; mp2["000001"]="ADD"; mp2["000010"]="SUB"; mp2["000011"]="DIV"; mp2["000100"]="MUL"; mp2["000101"]="MOVE"; mp2["000110"]="SET"; while(scanf("%d",&kind)!=EOF){ if(kind==1){ char ins[50],yu[50]; int ra,rb=0; scanf("%s%s",ins,yu); if(strcmp(ins,"SET")==0) ra=calc(yu,1,strlen(yu)-1); else{ int tc=findyu(yu,','); ra=calc(yu,1,tc-1); rb=calc(yu,tc+2,strlen(yu)-tc-2); } cout<
31){ cout<<"Error!"<
31 || rb<1 || rb>31){ cout<<"Error!"<

 

转载于:https://www.cnblogs.com/fish7/p/4077363.html

你可能感兴趣的文章
MSChart的研究
查看>>
C# 索引器
查看>>
MySQLdb & pymsql
查看>>
zju 2744 回文字符 hdu 1544
查看>>
delphi 内嵌汇编例子
查看>>
【luogu P2298 Mzc和男家丁的游戏】 题解
查看>>
前端笔记-bom
查看>>
MATLAB作图方法与技巧(一)
查看>>
上海淮海中路上苹果旗舰店门口欲砸一台IMAC电脑维权
查看>>
Google透露Android Market恶意程序扫描服务
查看>>
给mysql数据库字段值拼接前缀或后缀。 concat()函数
查看>>
迷宫问题
查看>>
【FZSZ2017暑假提高组Day9】猜数游戏(number)
查看>>
泛型子类_属性类型_重写方法类型
查看>>
eclipse-将同一个文件分屏显示
查看>>
mysql5.x升级至mysql5.7后导入之前数据库date出错的解决方法!
查看>>
对闭包的理解
查看>>
练习10-1 使用递归函数计算1到n之和(10 分
查看>>
Oracle MySQL yaSSL 不明细节缓冲区溢出漏洞2
查看>>
windows编程ASCII问题
查看>>