USACO2.2 Preface Numbering【思维+打表】
这道题乍一看没有什么思路,细看还是没有什么思路
嗯,细看还是可以看出些什么端倪。
不能复合嵌套什么的 总结一下就只有这样3种规则:
1.IXCM最多三个同样连续 加起来
2.递减:加起来 注意VLD不连续出现
3.IXCM在比它大1级或2级的数前面 表示减
罗马数字各位独立
应该比较显然吧 如果去掉最高位 剩下的数用罗马数字表示的结果是一样的
在全加的情况下 更显然了:
比如268=100+100+50+10+5+1+1+1=CCLXVIII
68=50+10+5+1+1+1=LXVIII
有减法的情况下:由于一个可表示为10n的数出现在一个比它大1级或2级的数前
所以减法是在它对应的数量级运算的
1.1&5 1&10 个位级
2.10&50 10&100 十位级
3.100&500 100&1000 百位级
所以可以单独考虑每一位的情况
于是我们可以...打表?
打出每一位的数的情况
分别对应:下标标号 字母 和 字母所代表的数值
$1$ $I$ $1$
$2$ $V$ $5$
$3$ $X$ $10$
$4$ $L$ $50$
$5$ $C$ $100$
$6$ $D$ $500$
$7$ $M$ $1000$
千位:$3$:$MMM$ $2$:$MM$ $1$:$M$
百位:$9$:$CM$ $8$:$DCCC$ $7$:$DCC$ $6$:$DC$ $5$:$D$ $4$:$CD$ $3$:$CCC$ $2$:$CC$ $1$:$C$
十位:$9$:$XC$ $8$:$LXXX$ $7$:$LXX$ $6$:$LX$ $5$:$L$ $4$:$XL$ $3$:$XXX$ $2$:$XX$ $1$:$X$
个位:$9$:$ IX$ $8$:$VIII$ $7$:$VII$ $6$:$VI$ $5$:$V$ 4:$IV$ $3$:$III$ $2$:$II$ $1$:$I$
/*
ID: Starry21
LANG: C++
TASK: preface
*/
#include<iostream>
#include<string>
#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
#include<queue>
using namespace std;
#define N 70
#define ll long long
#define INF 0x3f3f3f3f
int n,res[];
char ans[]={'L','I','V','X','L','C','D','M','Y','T'};
/*
打出每一位的数的情况
1 I 1
2 V 5
3 X 10
4 L 50
5 C 100
6 D 500
7 M 1000
千位:3:MMM 2:MM 1:M
百位:9:CM 8:DCCC 7:DCC 6:DC 5:D 4:CD 3:CCC 2:CC 1:C
十位:9:XC 8:LXXX 7:LXX 6:LX 5:L 4:XL 3:XXX 2:XX 1:X
个位:9: IX 8:VIII 7:VII 6:VI 5:V 4:IV 3:III 2:II 1:I
*/
int tt[][]/*thousand table*/,ht[][],et[][]/*tens*/,st[][];
void Init()
{
tt[][]=,tt[][]=,tt[][]=;
ht[][]=,ht[][]=,ht[][]=,ht[][]=,ht[][]=,ht[][]=;
ht[][]=,ht[][]=,ht[][]=,ht[][]=,ht[][]=;
ht[][]=,ht[][]=,ht[][]=;
et[][]=,et[][]=,et[][]=,et[][]=,et[][]=,et[][]=;
et[][]=,et[][]=,et[][]=,et[][]=,et[][]=;
et[][]=,et[][]=,et[][]=;
st[][]=,st[][]=,st[][]=,st[][]=,st[][]=,st[][]=;
st[][]=,st[][]=,st[][]=,st[][]=,st[][]=;
st[][]=,st[][]=,st[][]=;
}
void work(int x)
{
int cnt=;
while(x)
{
cnt++;
int t=x%;
if(cnt==)
{
for(int i=;i<=;i++)
res[i]+=st[t][i];
}
if(cnt==)
{
for(int i=;i<=;i++)
res[i]+=et[t][i];
}
if(cnt==)
{
for(int i=;i<=;i++)
res[i]+=ht[t][i];
}
if(cnt==)
{
for(int i=;i<=;i++)
res[i]+=tt[t][i];
}
x=x/;
}
}
int main()
{
//freopen("preface.in","r",stdin);
//freopen("preface.out","w",stdout);
Init();
scanf("%d",&n);
for(int x=;x<=n;x++)
work(x);
for(int i=;i<=;i++)
if(res[i])
printf("%c %d\n",ans[i],res[i]);
return ;
}
Code
USACO2.2 Preface Numbering【思维+打表】的更多相关文章
- USACO 2.2 Preface Numbering
Preface Numbering A certain book's prefaces are numbered in upper case Roman numerals. Traditional R ...
- Preface Numbering
链接 分析:先打表需要用到的罗马数字,然后暴力转换,最后统计一下即可 /* PROB:preface ID:wanghan LANG:C++ */ #include "iostream&qu ...
- Preface Numbering序言页码
题面 (preface.pas/c/cpp) 一类书的序言是以罗马数字标页码的.传统罗马数字用单个字母表示特定的数值,以下是标准数字表: I 1 V 5 X 10 L 50 C 100 D 500 M ...
- 【USACO 2.2】Preface Numbering (找规律)
求 1-n 的所有罗马数字表达中,出现过的每个字母的个数. 分别对每个数的罗马表达式计算每个字母个数. 对于十进制的每一位,都是一样的规则,只是代表的字母不同. 于是我们从最后一位往前考虑,当前位由字 ...
- USACO Section 2.2: Preface Numbering
搬了leetcode的代码 /* ID: yingzho1 LANG: C++ TASK: preface */ #include <iostream> #include <fstr ...
- USACO Preface Numbering 构造
一开始看到这道题目的时候,感觉好难 还要算出罗马的规则. 但是仔细一看,数据规模很小, n 只给到3500 看完题目给出了几组样例之后就有感觉了 解题方法就是: n的每个十进制数 转换成相应的罗马数字 ...
- ACM-ICPC 2018 南京赛区网络预赛 J Sum (思维+打表)
https://nanti.jisuanke.com/t/30999 题意 f(i)表示i能拆分成两个数的乘积,且要求这两个数中各自都没有出现超过1次的质因子的方案数.每次给出n,求∑(n,i=1)f ...
- Problem E. Matrix from Arrays(杭电2018年多校第四场+思维+打表找循环节)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6336 题目: 题意:给你一个l个元素的数组a,用题目中的程序构造一个新的矩阵,询问q次,问以(x1,y ...
- USACO Section2.2 Preface Numbering 解题报告 【icedream61】
preface解题报告----------------------------------------------------------------------------------------- ...
随机推荐
- json校验失败的原因
如下原因会造成JSON校验失败,而且会让你不知道为什么失败 JSON字符串里的非数字型键值没有双引号 JSON中存在\t这样的制表符,看起来和空格一样,但是就是因为它的存在校验不通过.去掉就能过了. ...
- hadoop namenode切换
hdfs haadmin -transitionToActive --forcemanual nn1 将nn1强制转换为Active hdfs haadmin -transitionToStandby ...
- IPC 进程间通信方式——共享内存
共享内存 共享内存区域是被多个进程共享的一部分物理内存. 多个进程都可以把共享内存映射到自己的虚拟空间.所有用户空间的进程要操作共享内存,都要将其映射到自己的虚拟空间,通过映射的虚拟内存空间地址去操作 ...
- jquery pageX属性 语法
jquery pageX属性 语法 作用:pageX() 属性是鼠标指针的位置,相对于文档的左边缘. 语法:event.page 参数: 参数 描述 event 必需.规定要使用的事件.这个 ...
- CF603E Pastoral Oddities 优先队列+结论+LCT维护生成树
首先,一个神奇的结论:一个合法的方案存在的条件是每一个联通块的节点数都是偶数个的. 这个可以用数学归纳法简单证一证. 证出这个后,我们只需动态加入每一个边,并查看一下有哪些边能够被删除(删掉后联通块依 ...
- Unity3D_(游戏)甜品消消乐02_游戏核心算法
甜品消消乐01_游戏基础界面 传送门 甜品消消乐02_游戏核心算法 传送门 甜品消消乐03_游戏UI设计 传送门 GameManager脚本上修改Fill Time可以改变消消乐移动速度 实现过 ...
- 前端开发——让算法"动"起来
正文 当然在我们不清楚具体操作细节前我们可以先假设一下,我们能够用什么来实现.按照以前看过的排序动画我将其分为 1.Js操作Dom,再搭配简单的css 2.Canvas动画 之后在查资料的时候发现还有 ...
- C++入门经典-例6.8-gets_s与puts的应用
1:使用标准输入函数cin和格式化输入函数scanf时都存在这样一个问题:当输入空格时,程序不会接受空格符之后的内容内容. 输入函数gets_s与输出函数puts都只以结束符'\0'作为输入\输出结束 ...
- C++入门经典-例4.4-循环嵌套之求n的阶乘
1:代码如下: // 4.4.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> using ...
- 使用stringstream代替sprintf和sscanf
C++里面的字符串格式话 之前一直是用的sprintf和sscanf 比较麻烦的是要申请一个字符数组然后在调用 用stringstream就比较完美 int main(int narg,char** ...