Chinaunix首页 | 论坛 | 博客
  • 博客访问: 523952
  • 博文数量: 118
  • 博客积分: 10028
  • 博客等级: 上将
  • 技术积分: 1820
  • 用 户 组: 普通用户
  • 注册时间: 2007-11-07 18:46
文章分类

全部博文(118)

文章存档

2009年(12)

2008年(106)

我的朋友

分类: C/C++

2008-06-01 14:15:36

问题背景

如果一个整数的十六进制表示(不含前导0)中,前一半数字之和等于后一半数字之和,我们称它为公平数。
注意,如果该数的十六进制表示中包含奇数个数字,则正中间的数字既不属于前一半,又不属于后一半。

例如在十六进制下1+D=7+7,因此1DE77是公平数。数字E并不参与计算。
再例如,所有单个数字的十六进制数(即0~F)均为公平数,但F0不是(不能把F0补充前导0写成0F0,进而认为它是公平数)。

给出十六进制数 X, Y, K 和十六进制数字集合 S,求区间[X, Y]之内,有多少个公平数满足:

  • 十六进制表达式(不包含前导0)中每个数字均在集合S中
  • 并且为K的倍数

输入格式

输入第一行为数字集S,包含0~9以及大写字母A~F。
每个数字或字母最多出现一次。
第二行包含 3 个十六进制正整数K, X, Y,均不超过 10 个数字。

输出格式

仅一行,包含一个整数,即满足条件的公平数个数。

样例输入

124C
5 100 FFF

样例输出

4

样例解释

只有四个数满足条件:212,424,4C4,C1C。

阅读(1088) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~