PC/UVa 题号: 110106/10033 Interpreter (解释器)题解 c语言版
学到两个:
//ignore \n
cin.ignore();
//ignore a line
cin.ignore(1024, '\n');
#include<cstdio>
#include<iostream>
#include<string>
#include<algorithm>
#include<iterator>
#include<cstring> //uva 10033 Problem G: Interpreter
#define ONLINE_JUDGE using namespace std;
int regs[10];
int ram[1000]; int steps;
int pc=0;
int oper, arg1, arg2; void load_ram()
{
steps=0;
pc=0;
memset(regs, 0 ,sizeof(regs));
memset(ram, 0 ,sizeof(ram));
//string s;
char s[5];
int i=0;
//for(int i=0;getline(cin, s)&&s.length();i++)
for(int i=0;fgets(s, sizeof(s), stdin);i++)
{
if(s[0]=='\n')
{
// printf("\\n \n");
break;
}
//ram[i]=atoi(s.c_str());
ram[i]=atoi(s);
#ifndef ONLINE_JUDGE
cout<<ram[i]<<endl;
#endif
} } void decode()
{
oper=ram[pc]/100;
arg1=ram[pc]/10%10;
arg2=ram[pc]%10;
pc++; steps++;
#ifndef ONLINE_JUDGE
printf("steps %d pc %d: %d %d %d\n", steps, pc-1, oper, arg1, arg2);
#endif } void run()
{
while(1)
{
decode();
switch(oper)
{
//halt
case 1:
goto END;
break;
//2dn means set register d to n (between 0 and 9)
case 2:
regs[arg1]=arg2;
break;
//3dn means add n to register d
case 3:
regs[arg1]+=arg2;
regs[arg1]%=1000;
break;
//4dn means multiply register d by n
case 4:
regs[arg1]*=arg2;
regs[arg1]%=1000;
break;
//5ds means set register d to the value of register s
case 5:
regs[arg1]=regs[arg2];
break;
//6ds means add the value of register s to register d
case 6:
regs[arg1]+=regs[arg2];
regs[arg1]%=1000;
break;
//7ds means multiply register d by the value of register s
case 7:
regs[arg1]*=regs[arg2];
regs[arg1]%=1000;
break;
//8da means set register d to the value in RAM whose address is in register a
case 8:
regs[arg1]=ram[regs[arg2]];
break;
//9sa means set the value in RAM whose address is in register a to the value of register s
case 9:
ram[regs[arg2]]=regs[arg1];
break;
//0ds means goto the location in register d unless register s contains 0
case 0:
if(regs[arg2]!=0)
pc=regs[arg1];
break;
default:
break;
} }
END:
return; } int main()
{
int n;
bool first=true;
char instr[5]={0};
//cin>>n;
scanf("%d", &n);
//ignore \n
//cin.ignore();
fgets(instr, sizeof(instr), stdin);
memset(instr, 0, sizeof(instr)); //ignore a line
//cin.ignore(1024, '\n');
fgets(instr, sizeof(instr), stdin);
while(n-- >0)
{
load_ram();
run(); if(!first)
printf("\n");
printf("%d\n", steps);
first=false;
} return 0;
}
PC/UVa 题号: 110106/10033 Interpreter (解释器)题解 c语言版的更多相关文章
- PC/UVa 题号: 110105/10267 Graphical Editor (图形化编辑器)题解
#include<cstdio> #include<iostream> #include<string> #include<algorithm> #in ...
- PC/UVa 题号: 110104/706 LC-Display (液晶显示屏)题解
#include <string> #include <iostream> #include <cstring> #include <algorithm> ...
- PC/UVa 题号: 110101/100 The 3n+1 problem (3n+1 问题)
The 3n + 1 problem Background Problems in Computer Science are often classified as belonging to a ...
- 23、Interpreter 解释器模式
1.Interpreter 解释器模式 解释器模式是一种使用频率相对较低但学习难度较大的设计模式,它用于描述如何使用面向对象语言构成一个简单的语言解释器.在某些情况下,为了更好地描述某一些特定类型的问 ...
- 二十三、Interpreter 解释器模式
设计: 代码清单: Node public abstract class Node { public abstract void parse(Context context) throws Parse ...
- 设计模式15:Interpreter 解释器模式(行为型模式)
Interpreter 解释器模式(行为型模式) 动机(Motivation) 在软件构建过程中,如果某一特定领域的问题比较复杂,类似的模式不断重复出现,如果使用普通的编程方式来实现将面临非常频繁的变 ...
- uva题库爬取
每次进uva都慢的要死,而且一步一步找到自己的那个题目简直要命. 于是,我想到做一个爬取uva题库,记录一下其中遇到的问题. 1.uva题目的链接是一个外部的,想要获取https资源,会报出SNIMi ...
- 【OCP|052】OCP最新题库解析(052)--小麦苗解答版
[OCP|052]OCP最新题库解析(052)--小麦苗解答版 OCP最新题库解析历史连接(052):http://mp.weixin.qq.com/s/bUgn4-uciSndji_pUbLZfA ...
- emlog 百度熊掌号提交插件-基于Emlog6.0.1特别版美化
插件截图 插件简介 此插件在发布文章的时候自动向百度熊掌号提交,有利于百度熊掌号收录.基于Emlog6.0.1特别版美化的插件. 在百度推送插件的基础上修改制作而成与百度推送共存,解放双手,走向人生巅 ...
随机推荐
- NavieBayes中的多项式与伯努力模型
1文本分类过程 例如文档:Good good study Day day up可以用一个文本特征向量来表示,x=(Good, good, study, Day, day , up).在文本分类中,假设 ...
- T-SQL查询进阶-10分钟理解游标
转:http://www.cnblogs.com/CareySon/archive/2011/11/01/2231381.html 概述 游标是邪恶的! 在关系数据库中,我们对于查询的思考是面向集合的 ...
- Canvas处理头像上传
未分类 最近社区系统需要支持移动端,其中涉及到用户头像上传,头像有大中小三种尺寸,在PC端,社区用Flash来处理头像编辑和生成,但该Flash控件的界面不友好而且移动端对Flash的支持不好,考虑到 ...
- Redis源码分析系列
0.前言 Redis目前热门NoSQL内存数据库,代码量不是很大,本系列是本人阅读Redis源码时记录的笔记,由于时间仓促和水平有限,文中难免会有错误之处,欢迎读者指出,共同学习进步,本文使用的Red ...
- 用javascript 面向对象制作坦克大战(三)
之前,我们完成了坦克的移动和地图的绘制,这次我们来完成碰撞检测和炮弹的发射. 上代码前来张最新的类图: 3. 碰撞检测 前面我们已经完成了坦克的移动和地图的绘制,下面我们开始写碰撞检测. 3. ...
- DzzOffice添加动态壁纸例子-Bing每日壁纸
Bing每日壁纸介绍:bing网站每天会更新一张不同的精选图片. 此压缩包内的程序,可以自动同步更新cn.bing.com网站每天更新的图片,作为dzzoffice的壁纸使用.实现自动每天更换不同的云 ...
- 【跟我一起学Python吧】Python 多线程
其实自我感觉Python的多线程很类似于Java的多线程机制,但是比JAVA的多线程更灵活.在早期的Python多线程实现中,采用了thread模块.例如: from time import ctim ...
- mybatis系列-12-多对多查询
12.1 需求 查询用户及用户购买商品信息. 12.2 sql语句 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关联表: orders.or ...
- Bias/variance tradeoff
线性回归中有欠拟合与过拟合,例如下图: 则会形成欠拟合, 则会形成过拟合. 尽管五次多项式会精确的预测训练集中的样本点,但在预测训练集中没有的数据,则不能很好的预测,也就是说有较大的泛化误差,上面的右 ...
- sublime text 2使用经验
1. Package Control 安装代码: import urllib2,os; pf='Package Control.sublime-package'; ipp=sublime.instal ...