幸运串

题意:长度为n,字符集大小为m的字符串中有多少不同的不含回文的串

n,m<10^9


我靠这不就是萌数的DP部分吗

有规律

f[2][j][k]=1

f[i][j][k]=sigma{f[i-1][k][z]|z!=j&&z!=k}

答案就是m*(m-1)*(m-2)^(n-2)

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const ll MOD=1e9+;
ll n,m;
inline ll powMod(ll a,ll b){
ll ans=;
for(;b;b>>=,a=(a*a)%MOD)
if(b&) ans=(ans*a)%MOD;
return ans;
}
int main(){
freopen("lucky.in","r",stdin);
freopen("lucky.out","w",stdout);
scanf("%lld%lld",&n,&m);
if(m==) printf("%d",n==?:);
else if(n==) printf("%d\n",m);
else printf("%lld",m*(m-)%MOD*powMod(m-,n-)%MOD);
}


最优排名

很明显贪心

先v大到小排序

找之前w-v最小的,送她气球,删掉它;送气球之后加入后面又超过自己的

用set超时了,直接用堆就好,只需要删除最大元素

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <set>
using namespace std;
const int N=3e5+;
typedef long long ll;
inline ll read(){
char c=getchar();ll x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int n;
struct team{
int id;
ll w,v;
bool operator <(const team &r)const{return v>r.v;}
}a[N]; multiset<ll> s;
int main(){
freopen("rank11.in","r",stdin);
freopen("rank11.out","w",stdout); n=read();
for(int i=;i<=n;i++) a[i].id=i,a[i].v=read(),a[i].w=read();
sort(a+,a++n);
ll p=,rank;
for(int i=;i<=n;i++){
if(a[i].id==) break;
p++;
s.insert(a[i].w-a[i].v+);
}
rank=p+;//printf("rank %d\n",rank);
ll v=a[rank].v,ans=rank,tail=rank+;
while(v&&!s.empty()){
ll now=*s.begin(); //printf("now %d\n",now);
s.erase(s.begin());
if(v-now>=) v-=now,rank--;
while(v<a[tail].v) {s.insert(a[tail].w-a[tail].v+);tail++;rank++;}
ans=min(ans,rank);
}
printf("%d",ans);
}
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
using namespace std;
const int N=3e5+;
typedef long long ll;
inline ll read(){
char c=getchar();ll x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int n;
struct team{
int id;
ll w,v;
bool operator <(const team &r)const{return v>r.v;}
}a[N]; priority_queue<ll,vector<ll>,greater<ll> > q;
int main(){
freopen("rank.in","r",stdin);
freopen("rank.out","w",stdout); n=read();
for(int i=;i<=n;i++) a[i].id=i,a[i].v=read(),a[i].w=read();
sort(a+,a++n);
ll p=,rank;
for(int i=;i<=n;i++){
if(a[i].id==) break;
p++;
q.push(a[i].w-a[i].v+);
}
rank=p+;//printf("rank %d\n",rank);
ll v=a[rank].v,ans=rank,tail=rank+;
while(v&&!q.empty()){
ll now=q.top();q.pop();
if(v-now>=) v-=now,rank--;
while(v<a[tail].v) {q.push(a[tail].w-a[tail].v+);tail++;rank++;}
ans=min(ans,rank);
}
printf("%d",ans);
}


运输任务

貌似是树链剖分,不会

能骗20到50分吧

最新文章

  1. ASP.NET MVC 5 入门指南汇总
  2. 今天主要推荐一下django学习的网址!
  3. CSS生成内容
  4. Func&lt;T, TResult&gt; Delegate
  5. iOS开发---集成ShareSDK实现第三方登录、分享、关注等功能。
  6. bzoj AC 50 庆祝~~
  7. Android 模仿QQ空间风格的 UI(转)
  8. android 菜单事件处理
  9. Visual Studio之Nuget
  10. Java 并发专题 : Semaphore 实现 互斥 与 连接池
  11. Nginx rewrite 规则 与 proxy_pass 实现
  12. 从头开始基于Maven搭建SpringMVC+Mybatis项目(1)
  13. 在Linux上要安装SSH协议
  14. SpringBoot整合Shiro使用Ehcache等缓存无效问题
  15. 1038. Jewels And Stones
  16. Django-ORM 复习
  17. 使用git和github进行协同开发流程
  18. python安装提示ImportError: No module named web
  19. Django框架----ORM数据库操作注意事项
  20. The attribute required is undefined for the annotation type XmlElementRef

热门文章

  1. Asp.net 面向接口可扩展框架之应用程序上下文作用域组件
  2. 如何在ASP.NET的web.config配置文件中添加MIME类型
  3. 将GridView数据导入到excel,并提供下载
  4. Struts2基于注解的Action配置
  5. PHP 字符串左边补0,字符串右边补0
  6. hibernate理解
  7. Css动画总结
  8. nth-child和:nth-of-type的区别
  9. Android开发1:基本UI界面设计——布局和组件
  10. 谈谈Fragment中的onActivityResult