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 ...
随机推荐
- 【HDU 2577】How to Type
题意 (我做了这题才知道caps lock 锁定大小写后,按一下shift键可以输入相反的大小写.) 这题就是给你只有大小写字母的字符串,求最少多少次按键盘.最后caps lock 必须是关闭的. 分 ...
- 【BZOJ】【1009】 【HNOI2008】GT考试
DP/KMP/矩阵乘法 好神的题啊……跪了跪了 $n\leq 10^9$是什么鬼……我们还是先不要考虑这个鬼畜的玩意了>_> 用类似数位DP的思路,我们可以想到一个DP方程:$f[i][j ...
- POJ1002 487-3279
Description 企业喜欢用容易被记住的电话号码.让电话号码容易被记住的一个办法是将它写成一个容易记住的单词或者短语.例如,你需要给滑铁卢大学打电话时,可以拨打TUT-GLOP.有时,只将电话号 ...
- POJ 2559 Largest Rectangle in a Histogram
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18942 Accepted: 6083 Description A hi ...
- uva 10723 Cyborg Genes(LCS变形)
题目:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=107450#problem/C 题意:输入两个字符串,找一个最短的串,使得输入的两个 ...
- rockmongo用法
.简单查询 //xid=560870 and type=video { , "type": "video" } //查询数组中的数据 array( " ...
- 教你看懂网上流传的60行JavaScript代码俄罗斯方块游戏
早就听说网上有人仅仅用60行JavaScript代码写出了一个俄罗斯方块游戏,最近看了看,今天在这篇文章里面我把我做的分析整理一下(主要是以注释的形式). 我用C写一个功能基本齐全的俄罗斯方块的话,大 ...
- 数数字 (Digit Counting,ACM/ICPC Danang 2007,UVa 1225)
思路: 利用java 特性,将数字从1 一直加到n,全部放到String中,然后依次对strring扫描每一位,使其carr[str.charAt(i)-'0']++; 最后输出carr[i],即可. ...
- error MSB4019: 未找到导入的项目“C:\Program Files (x86)\MSBuild\Microsoft\VisualStudio\v11.0\WebApplications\Microsoft.WebApplication.targets”
error MSB4019: 未找到导入的项目“C:\Program Files (x86)\MSBuild\Microsoft\VisualStudio\v11.0\WebApplications\ ...
- SQL injection
SQL injection is a code injection technique, used to attack data-driven applications, in which malic ...