BestCoder15 1002.Instruction(hdu 5083) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5083
题目意思:如果给出 instruction 就需要输出对应的 16-bit binary code,给出16-bit binary code 就需要输出对应的instruction。
由于不会截取的技巧,代码量非常可观 = =,所以说,一直很讨厌做模拟题!!!
留下这代码,纪念一个代码还是不够精简的自己!!!内存和时间还能接受,也比较容易理解,不过好多重复代码= =。以下这个代码可以忽略,改到晕= =。之后会补上简单容易理解版滴......
一...场.......噩..........梦!!!
78Ms 284K 5708B
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std; const int maxn = + ;
const int N = + ;
char instruct[][N] = {"", "ADD", "SUB", "DIV", "MUL", "MOVE", "SET"};
char num_instruct[][N] = {"", "", "", "", "", "", ""}; char R[][N] = {"", "R1", "R2", "R3", "R4", "R5", "R6", "R7", "R8",
"R9", "R10", "R11", "R12", "R13", "R14", "R15", "R16",
"R17", "R18", "R19", "R20", "R21", "R22", "R23", "R24",
"R25", "R26", "R27", "R28", "R29", "R30", "R31"};
char num_R[][N] = {"", "", "", "", "", "", "",
"", "", "", "", "", "", "",
"", "", "", "", "", "", "",
"", "", "", "", "", "", "",
"", "", "", ""}; char s1[N], s2[maxn];
char s[maxn]; int main()
{
#ifndef ONLINE_JUDGE
freopen("ljy.txt", "r", stdin);
#endif int ask;
while (scanf("%d", &ask) != EOF)
{
char tmp1[N], tmp2[N];
if (ask == )
{
int i;
scanf("%s%s", s1, s2);
for (i = ; i < ; i++)
{
if (!strcmp(s1, instruct[i]))
{
printf("%s", num_instruct[i]);
break;
}
}
if (!strcmp(s1, "SET")) // SET指令单独处理
{
for (i = ; i < ; i++)
{
if (!strcmp(s2, R[i]))
{
printf("%s00000\n", num_R[i]);
break;
}
}
}
else
{
int l1 = ;
int len = strlen(s2);
for (i = ; i < len; i++)
{
if (s2[i] == ',')
break;
tmp1[l1++] = s2[i];
}
tmp1[l1] = '\0'; // 截取Rdestination
int r = i+;
for (i = ; i < ; i++)
{
if (!strcmp(tmp1, R[i]))
{
printf("%s", num_R[i]);
break;
}
}
int l2 = ;
for (i = r; i < len; i++)
tmp2[l2++] = s2[i];
tmp2[l2] = '\0'; // 截取Rsource
for (int i = ; i < ; i++)
{
if (!strcmp(tmp2, R[i]))
{
printf("%s\n", num_R[i]);
break;
}
}
}
}
else
{
scanf("%s", s);
char ans[][maxn];
int len1 = strlen(s);
int l1 = ;
for (int i = ; i < ; i++)
tmp1[l1++] = s[i];
tmp1[l1] = '\0';
bool flag = false;
for (int i = ; i < ; i++)
{
if (!strcmp(tmp1, num_instruct[i]))
{
strcpy(ans[], instruct[i]); // 有可能是SET指令,这要继续往后看判断
flag = true;
break;
}
}
if (!flag) // 找不到指令匹配
printf("Error!\n");
else
{
int l1 = ;
for (int i = ; i < ; i++)
tmp1[l1++] = s[i];
tmp1[l1] = '\0'; // Rdestination int l2 = ;
for (int i = ; i < ; i++)
tmp2[l2++] = s[i];
tmp2[l2] = '\0'; // Rsource if (!strcmp(ans[], "SET"))
{
if (!strcmp(tmp2, "") && strcmp(tmp1, "")) // 符合条件的形式:000110?????00000
{
for (int i = ; i < ; i++)
{
if (!strcmp(tmp1, num_R[i]))
{
printf("SET %s\n", R[i]);
break;
}
}
}
else
printf("Error!\n");
} else
{
if (!strcmp(tmp2, "") || !strcmp(tmp1, "")) // 不合法的Registers
printf("Error!\n");
else
{
printf("%s ", ans[]); // 除SET之外的其他指令
for (int i = ; i < ; i++)
{
if (!strcmp(tmp1, num_R[i]))
{
printf("%s,", R[i]);
break;
}
}
for (int i = ; i < ; i++)
{
if (!strcmp(tmp2, num_R[i]))
{
printf("%s\n", R[i]);
break;
}
}
}
}
}
}
}
return ;
}
简化版: 62Ms 292K 2787B
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std; const int N = + ;
char instruct[][N] = {"", "ADD", "SUB", "DIV", "MUL", "MOVE", "SET"}; char s1[*N], s2[*N];
char ans[*N]; inline void ins_to_binary(int end, int st, int a)
{
for (int i = end; i >= st; i--)
{
ans[i] = a % + '';
a >>= ;
}
} inline void binary_to_ins(int end, int st, int &a)
{
int k = ;
for (int i = end; i >= st; i--)
{
a += (s1[i] - '') * k;
k <<= ;
}
} int main()
{
int ask, a1, a2, a3;
while (scanf("%d", &ask) != EOF)
{
if (ask == )
{
scanf("%s%s", s1, s2);
for (int i = ; i <= ; i++)
{
if (strcmp(s1, instruct[i]) == )
{
a1 = i;
break;
}
}
if (a1 == ) // SET 指令
a3 = ;
else
{
int k = ;
a3 = ;
for (int i = strlen(s2)-; i > ; i--) // R2
{
if (s2[i] == 'R')
break;
else
{
a3 += (s2[i] - '') * k;
k *= ;
}
}
}
if (s2[] == ',' || s2[] == '\0') // R1 为个位数
a2 = s2[] - '';
else
a2 = (s2[]-'') * + s2[]-''; // R1 为十位数 ins_to_binary(, , a3);
ins_to_binary(, , a2);
ins_to_binary(, , a1);
ans[] = '\0';
printf("%s\n", ans);
}
else
{
scanf("%s", s1);
a1 = a2 = a3 = ;
binary_to_ins(, , a1);
if (a1 > || a1 == ) // 找不到合适指令
printf("Error!\n");
else
{
binary_to_ins(, , a3); // SET指令R2!=0
if (a1 == && a3 > )
printf("Error!\n");
else
{
binary_to_ins(, , a2);
if (a2 == || a3 == && a1 != ) // 除SET其他指令R1!=0
printf("Error!\n");
else if (a1 == )
printf("SET R%d\n", a2);
else
printf("%s R%d,R%d\n", instruct[a1], a2, a3);
}
}
}
}
return ;
}
BestCoder15 1002.Instruction(hdu 5083) 解题报告的更多相关文章
- BestCoder17 1002.Select(hdu 5101) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5101 题目意思:给出 n 个 classes 和 Dudu 的 IQ(为k),每个classes 都有 ...
- BestCoder20 1002.lines (hdu 5124) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5124 题目意思:给出 n 条线段,每条线段用两个整数描述,对于第 i 条线段:xi,yi 表示该条线段 ...
- BestCoder18 1002.Math Problem(hdu 5105) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5105 题目意思:给出一个6个实数:a, b, c, d, l, r.通过在[l, r]中取数 x,使得 ...
- BestCoder6 1002 Goffi and Squary Partition(hdu 4982) 解题报告
题目链接:http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?pid=1002&cid=530 (格式有一点点问题,直接粘 ...
- BestCoder22 1002.NPY and arithmetic progression(hdu 5143) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5143 题目意思:给出 1, 2, 3, 4 的数量,分别为a1, a2, a3, a4,问是否在每个数 ...
- BestCoder16 1002.Revenge of LIS II(hdu 5087) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5087 题目意思:找出第二个最长递增子序列,输出长度.就是说,假如序列为 1 1 2,第二长递增子序列是 ...
- BestCoder12 1002.Help him(hdu 5059) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5059 题目意思:就是输入一行不多于 100 的字符串(除了'\n' 和 '\r' 的任意字符),问是否 ...
- BestCoder10 1002 Revenge of GCD(hdu 5019) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5019 题目意思:给出 X 和 Y,求出 第 K 个 X 和 Y 的最大公约数. 例如8 16,它们的公 ...
- BestCoder8 1002 Revenge of Nim(hdu 4994) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4994 题目意思:有 n 个 heap(假设从左至右编号为1-n),每个 heap 上有一些 objec ...
随机推荐
- MyEclipse10中导入的jquery文件报错(出现红叉叉,提示语法错误)
为了做一个页面特效,导入了一个jQuery文件,怎想,myeclipse竟然报错说是语法错误,但是这个js文件我是从官网上下载的,不应该出错才对,百度谷歌之后终于找到了解决办法: 选中报错的js文件, ...
- 【poj1015】 Jury Compromise
http://poj.org/problem?id=1015 (题目链接) 题意 随机挑选n个人作为陪审团的候选人,然后再从这n个人中选m 人组成陪审团.选m人的办法是:控方和辩方会根据对候选人的喜欢 ...
- Java虚拟机类加载机制
看到这个题目,很多人会觉得我写我的java代码,至于类,JVM爱怎么加载就怎么加载,博主有很长一段时间也是这么认为的.随着编程经验的日积月累,越来越感觉到了解虚拟机相关要领的重要性.闲话不多说,老规矩 ...
- File类的创建,删除文件
File.Create(@"C:\Users\shuai\Desktop\new.txt"); Console.WriteLine("创建成功"); Conso ...
- linux建立用户 详细
.你同时属于两个或两个以上的组. 两个条件你至少具备一个,你才能够把文件所属旧组变为新组.使用如下的命令将当前目录下所有html文件所属的组改为httpd: chgrp httpd *.html 和c ...
- Java初学(三)
一.使用键盘录入数据 三步:1.导入包:import java.util.Scanner; 2.创建键盘录入对象:Scanner sc=new Scanner(System.in); 3.通过 ...
- alert对ajax阻塞调查(IE, Chrome, FF)
前阵子做保守工作,对一个js效果进行了改进,由于自己在chrome下测试没问题就丢给同事测试,同事用的是FF,发现不正常,后来又发现这个js在IE10下也不行,不得不调查,结果发现Chrome的ale ...
- background总结
1. background-position background-position的百分比属性规则是:图片本身(x%,y%)的那个点,与背景区域的(x%,y%)的那个点重合. 具体可参考: http ...
- mappedBy reference an unknown target entity property解决方法
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error ...
- sturct stat 结构体中 st_mode 的含义
工作中遇到 else if( (s_buf.st_mode&S_IFMT) == S_IFDIR) return 2; else if( !(s_buf.st_mode&S_IFREG ...