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 ...
随机推荐
- Yii2 radioList设置默认值
可以在对应的Controller的action中设置 $model->type = 1; 在view中 <?php $form = ActiveForm::begin(); ?> ...
- dict内部方法
代码: #dict内部方法 vdic={'name':'kamil','age':23} print(dir(vdic)) vdic1 = vdic.copy()#copy(self):浅拷贝 pri ...
- BZOJ-4010 菜肴制作 贪心+堆+(拓扑图拓扑序)
无意做到...char哥还中途强势插入干我...然后据他所言,看了一会题,一转头,我爆了正解....可怕 4010: [HNOI2015]菜肴制作 Time Limit: 5 Sec Memory L ...
- poj 1006 中国剩余定理解同余方程
其实画个图就明白了, 该问题就是求同余方程组的解: n+d≡p (mod 23) n+d≡e (mod 28) n+d≡i (mod 33) #include "iostream" ...
- 从js的repeat方法谈js字符串与数组的扩展方法
js将字符串重复N次的repeat方法的8个版本 /* *@desc: 将一个字符串重复自身N次 */ //版本1:利用空数组的join方法 function repeat(target, n) { ...
- Ubuntu学习总结-06 安装 Nginx
Nginx是由俄罗斯人(zhan dou min zu)开发的一款高性能的http和反向代理服务器,也可以用来作为邮件代理.相比较于其他的服务器,具有占用内存少,稳定性高等优势. 一 Ubuntu源码 ...
- Enum类型 枚举内部值/名
enum Days { Nothing=0, Mon=1, Stu=2 } static void Main(string[] args) { foreach (int item in Enum.Ge ...
- php网站验证码的生成
<?php header("Content-type:text/html;charset=utf-8"); header("Content-type:image/p ...
- yum被锁Another app is currently holding the yum lock; waiting for it to exit...
可能是系统自动升级正在运行,yum在锁定状态中. 可以通过强制关掉yum进程: #rm -f /var/run/yum.pid 然后就可以使用yum了.
- TFS2008解除独占式锁定文件命令(转载)
使用场景:如果项目团队成员A对项目某个文件以独占式方式签出,恰好那天该成员A没有来上班而成员需要对此文件进入修改并check in,这时需要先把A对该文件的锁定解除.没有IDE可以使用,只能使用下面的 ...