这三道题都水的难以想象,所以就放在一起写

1850

题目大意:有一种一种序列排列方式(如同题目中给出的例子),然后给你一个序列,问你这个序列的排名

首先我们先判断无解的情况,这个就很简单了。

由于题目给出的排列方式我们知道:若这个序列不满足一直上升的情况,那么一定无解

很好理解吧,然后我们进一步分析:在有解的情况下,如果构成这种序列的所有字符都确定了,那么它们的顺序都唯一确定了

然后我们可以求出所有长度小于这个序列的序列的总排名,即ΣC[26][i] (1<=i<len)

然后对于所有长度和它一样的序列,枚举每一位上可以使用的比他小的字符,然后组合数退一下即可

具体看代码,这个很好理解

CODE

#include<cstdio>
#include<cstring>
using namespace std;
char s[15];
int C[30][30],len,ans=1,last;
inline void init(void)
{
for (register int i=1;i<=26;++i)
{
C[i][0]=1; C[i][i]=1;
for (register int j=1;j<i;++j)
C[i][j]=C[i-1][j]+C[i-1][j-1];
}
}
int main()
{
register int i,j;
init();
scanf("%s",s+1); len=strlen(s+1);
for (i=2;i<=len;++i)
if (s[i]<=s[i-1]) { puts("0"); return 0; }
for (i=1;i<len;++i)
ans+=C[26][i]; last=1;
for (i=1;i<=len;++i)
{
int now=s[i]-'a'+1;
for (j=last;j<now;++j)
ans+=C[26-j][len-i];
last=now+1;
}
printf("%d",ans);
return 0;
}

1019

这道题我愣是没看出来和组合数的关系

题意也是给你一串序列(直接看题目),这个规律明显。让你求它的第i项是多少

裸的枚举题。我们只需要先找出所以在它之前的完整结束的序列的数字总数,然后让n减去即可得出在当前这个序列中的第几项

然后我们稍作分析:

  • 一位数0~9,共9个,占用数字9*1=9个

  • 两位数10~99,共90个,占用数字90*2=180个

  • 三位数100~999,共900个占用数字900*3=2700个

  • ......

这个规律就很显然了吧,这样我们就可以直接得出它是哪个数的第几位,最后输出即可

具体看CODE

#include<cstdio>
using namespace std;
typedef long long LL;
LL t,sum,n,num,last;
inline LL pow_10(LL k)
{
LL tot=1;
for (register LL i=1;i<=k;++i)
tot*=10;
return tot;
}
inline LL get(LL x,LL w)
{
while (w--) x/=10;
return x%10;
}
inline LL len(LL x)
{
int cnt=0;
while (x) ++cnt,x/=10;
return cnt;
}
int main()
{
register LL i; scanf("%lld",&t);
while (t--)
{
scanf("%lld",&n);
for (i=1,sum=0,last=0;;++i)
{
last+=len(i);
if (sum+last>=n) break; sum+=last;
}
n-=sum; sum=0;
for (i=1;;++i)
{
if (sum+pow_10(i-1)*9*i>=n) { num=i; break; } sum+=pow_10(i-1)*9*i;
} n-=sum;
if (!num) { printf("%lld\n",n); continue; }
if (n%num) printf("%lld\n",get(pow_10(num-1)+n/num,num-n%num)); else printf("%lld\n",get(pow_10(num-1)+n/num-1,0));
}
return 0;
}

1942

这道题是真心水,题意就是从一个方格图的左下角走到右上角的方案总数(沿着边走)

这题用递推法绝壁或超时,但是求方案数的话我们可以直接考虑这么一种想法:

首先我们观察到向右永远走n步,向上永远走m步,总步数永远是n+m

然后不同的方案本质其实就是它们的排列组合不同

然后稍加推导就是从n+m个地方里面选取n个填上数的方案数

即要求的就是:C(n+m,n)||C(n+m,m)

但是这里用阶乘的会爆精度,递推法又会超时,不过由于题目说明答案一定在unsighed int 范围内,所以我们只能用约分法

首先对于,C(n+m,n)有:

然后我们将上下都消去n!,则:

然后就可以得到:

ans=ans*(i+n)/i(1<=i<=m)

不停除下去即可,这里我们总是选取n,m中小的一个来进行循环可以快一点

CODE

#include<cstdio>
#include<cmath>
using namespace std;
long long n,m;
inline char tc(void)
{
static char fl[100000],*A=fl,*B=fl;
return A==B&&(B=(A=fl)+fread(fl,1,100000,stdin),A==B)?EOF:*A++;
}
inline void read(long long &x)
{
x=0; char ch=tc();
while (ch<'0'||ch>'9') ch=tc();
while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=tc();
}
inline void write(long long x)
{
if (x/10) write(x/10);
putchar(x%10+'0');
}
inline void swap(long long &a,long long &b)
{
long long t=a; a=b; b=t;
}
inline long long calc(long long n,long long m)
{
long long tot=1.0;
for (register long long i=1;i<=n;++i)
tot=tot*(m+i)/i;
return tot;
}
int main()
{
//freopen("CODE.in","r",stdin); freopen("CODE.out","w",stdout);
for (;;)
{
read(n); read(m);
if (!n&&!m) break;
if (n>m) swap(n,m);
write(calc(n,m)); putchar('\n');
}
return 0;
}

POJ1850&&1019&&1942的更多相关文章

  1. 【转】POJ题目分类

    初级:基本算法:枚举:1753 2965贪心:1328 2109 2586构造:3295模拟:1068 2632 1573 2993 2996 图:最短路径:1860 3259 1062 2253 1 ...

  2. 1019: [SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1495  Solved: 916[Submit][Status] ...

  3. acm之poj题库1019方法

    认识了几个师弟,一直总想把自己的经验表达出来一些,让后面的人在更年轻的时候,认识到方向.努力. 昨天忽然想起自己在大学时候做了几天的acm,终于也没能坚持.然后就感觉带师弟们做下acm题目还是很不错. ...

  4. BZOJ 1019: [SHOI2008]汉诺塔

    Description 一个汉诺塔,给出了移动的优先顺序,问从A移到按照规则移到另一个柱子上的最少步数. 规则:小的在大的上面,每次不能移动上一次移动的,选择可行的优先级最高的. Sol DP. 倒着 ...

  5. hud 1019最小公倍数

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1019 思路:头两个数先求,再用所求的数与后面的一个数求,依次类推 #include<stdlib ...

  6. Light OJ 1019 - Brush (V)(图论-dijkstra)

    题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1019 题目大意:Tanvir想从节点1的位置走到节点n的位置, 输出最短距离, ...

  7. 【BZOJ 1019】【SHOI2008】汉诺塔(待定系数法递推)

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 559  Solved: 341[Submit][Status] ...

  8. 【BZOJ】1019: [SHOI2008]汉诺塔

    http://www.lydsy.com/JudgeOnline/problem.php?id=1019 题意:汉诺塔规则,只不过盘子n<=30,终点在B柱或C柱,每一次移动要遵守规则:1.小的 ...

  9. 1019: A+B和C比大小

    1019: A+B和C比大小 时间限制: 1 Sec  内存限制: 128 MB提交: 518  解决: 300[提交][状态][讨论版] 题目描述 给定区间[-231, 231]内的3个整数A.B和 ...

随机推荐

  1. 安卓开发----TextView控件属性列表(转)

    文章原地址: http://wwzcraig.blog.163.com/blog/static/64622969201373184343118/ android:autoLink设置是否当文本为URL ...

  2. Core Animation-2:寄宿图

    #寄宿图 >图片胜过千言万语,界面抵得上千图片  ——Ben Shneiderman 我们在第一章『图层树』中介绍了CALayer类并创建了一个简单的有蓝色背景的图层.背景颜色还好啦,但是如果它 ...

  3. 51Testing专访史亮:测试人员在国外

    不久前,我接受了51Testing的访问,讨论了软件测试的一些问题.以下是全文. 1.史亮老师,作为我们51Testing的老朋友,能和我们说说您最近在忙些什么吗? 自2011年起,我加入Micros ...

  4. vue axios 与 FormData 结合 提交文件 上传文件

    ---再利用Vue.axios.FormData做上传文件时,遇到一个问题,后台虽然接收到请求,但是将文件类型识别成了字符串,所以,web端一直报500,结果是自己大意了. 1.因为使用了new  F ...

  5. AJAX的优点 个人理解记录

    1:对网站性能的提高.例如我只需要刷新页面中购物车的数据,使用ajax时不需要请求整个页面的数据,对于客户端和服务器的压力都会降低, 减少了ISP的负担,服务器的空间和带宽压力都会降低. 2:用户体验 ...

  6. 对Spring的理解(简单)!

    1.Spring是对j2EE诸多功能进行封装了的一个工具集:它的核心就是提供了一种新的机制来管理业务对象及依赖关系:具体就是控制反转.依赖注入,Aop(面向切面). Spring的底层实现机制是用De ...

  7. python 机器学习中模型评估和调参

    在做数据处理时,需要用到不同的手法,如特征标准化,主成分分析,等等会重复用到某些参数,sklearn中提供了管道,可以一次性的解决该问题 先展示先通常的做法 import pandas as pd f ...

  8. ccf--20131203--最大矩形

    刚开始我是想依次计算i个相连矩形的面积,然后找出最大的面积,但是这种做法是时间复杂度是O(n*n),运行会超时. 这个是网上的一种做法,分别计算以第i个矩形作为高时,最大的面积.这就要以i为起始点,左 ...

  9. Beta冲刺(5/5)(麻瓜制造者)

    今日已完成 邓弘立:完成了图书馆新功能 符天愉:完成管理员用户查询,删除商品/需求以及注销功能 江郑:进行后台管理员的web开发 刘双玉:修改了商品搜索中数据返回类型不对的错误,添加了图书馆查询接口 ...

  10. HDU3949 XOR

    嘟嘟嘟 集训的时候发现自己不会线性基,就打算学一下. 这东西学了挺长时间,其实不是因为难,而是天天上午考试,下午讲题,结果晚上就开始颓了. 今天总算是有大块的时间好好学了一遍. 这里推荐menci大佬 ...