当前位置: 首页 > news >正文

南通优普网站建设制作广告公司的业务范围

南通优普网站建设制作,广告公司的业务范围,个体工商户能够做经营性网站吗,建设通网站有法律题目传送门 题面 [HNOI2008] 越狱 题目描述 监狱有 n n n 个房间,每个房间关押一个犯人,有 m m m 种宗教,每个犯人会信仰其中一种。如果相邻房间的犯人的宗教相同,就可能发生越狱,求有多少种状态可能发生越狱。 …

题目传送门

题面

[HNOI2008] 越狱

题目描述

监狱有 n n n 个房间,每个房间关押一个犯人,有 m m m 种宗教,每个犯人会信仰其中一种。如果相邻房间的犯人的宗教相同,就可能发生越狱,求有多少种状态可能发生越狱。

答案对 100 , 003 100,003 100,003 取模。

输入格式

输入只有一行两个整数,分别代表宗教数 m m m 和房间数 n n n

输出格式

输出一行一个整数代表答案。

样例 #1

样例输入 #1

2 3

样例输出 #1

6

提示

样例输入输出 1 解释
状态编号1 号房间2 号房间3 号房间
1信仰 1信仰 1信仰 1
2信仰 1信仰 1信仰 2
3信仰 1信仰 2信仰 2
4信仰 2信仰 1信仰 1
5信仰 2信仰 2信仰 2
6信仰 2信仰 2信仰 1
数据规模与约定

对于 100 % 100\% 100% 的数据,保证 1 ≤ m ≤ 1 0 8 1 \le m \le 10^8 1m108 1 ≤ n ≤ 1 0 12 1 \le n \le 10^{12} 1n1012

思路

先正常看,题目难度普及/提高,所以有很大的思维成分在里面。
然后的话这是标签:
在这里插入图片描述
明显这是一道排列组合题目。
先考虑会越狱情况下的各种情况
这是样例1的

状态编号1 号房间2 号房间3 号房间
1信仰 1信仰 1信仰 1
2信仰 1信仰 1信仰 2
3信仰 1信仰 2信仰 2
4信仰 2信仰 1信仰 1
5信仰 2信仰 2信仰 2
6信仰 2信仰 2信仰 1

很明显,从2个一样信仰的相邻一直到n个一样的信仰相邻都有多种可能,所以从这个方向考虑会很复杂。
那么可以换一种思路,从逆向来想,因为只有两种情况,要么越狱,要么不越狱,所以可以理解为 越狱的情况 = 所有情况 − 不越狱的情况 越狱的情况=所有情况-不越狱的情况 越狱的情况=所有情况不越狱的情况
那么考虑一下不越狱的情况。
有m中信仰的情况下,具体可以这样分配:

1 号房间2 号房间3 号房间3n号房间
m种信仰m-1种信仰m-1种信仰m-1种信仰m-1种信仰

因为为了不和上一个房间的宗教相同,所以剩下了除上一个房间以外m-1种信仰可选,然而第一间左边没有房间可以有m种选择。
因此我们可以把答案弄出来了
a n s = n m − m ∗ ( n − 1 ) m − 1 ans=n^m-m*(n-1)^{m-1} ans=nmm(n1)m1
接着看数据范围,保证 1 ≤ m ≤ 1 0 8 1 \le m \le 10^8 1m108 1 ≤ n ≤ 1 0 12 1 \le n \le 10^{12} 1n1012,所以如果用O(n)的时间复杂度会过不了( 1 0 8 10^8 108有的判题机好似可以过)
所以要用快速幂,原理就是倍增思想,时间复杂度降低到了 l o g ( n ) log(n) log(n)

虽然c++本身有快速幂函数pow,不过由于涉及取模,所以需要手写一个。

最后提交上去就会发现有的点WA了,由于这里面取模运算的特性,所以有可能会出现 n m n^m nm取模完以后比后面那一坨还小,这时候我们就应该加上一个模数就可以了

c o d e code code

#include<bits/stdc++.h>
using namespace std;
//#define ll long long防伪认证
#define ld long double
#define FOR(x,a,b,c) for(int x=a;x<=b;x+=c)
#define MFOR(x,a,b,c) for(int x=a;x>=b;x-=c)
#define MPFOR(x,a,b,c) for(int x=a;a<=b;x*=c)
const int N3=1e3+10;
const int N=1e6+10;
const long double esp=1e-8;
bool f[N];
/*/防伪认证
map<ll,int> a;
queue<int> a;
stack<int> a;
priority_queue<int> a;
vector<int> a;
set<int> a;
::iterator it
unordered
/*/
int gcd(int a,int b){int c=a%b;while(a%b!=0){a=b;b=c;c=a%b;}return b;
}
int lcm(int x,int y){return (x*y)/gcd(x,y);
}
void p(int n){f[1]=1;f[0]=1;for(int i=2;i*i<=n;i++){if(f[i]) continue;for(int j=i*i;j<=n;j+=i){f[j]=1;}}
}
ll qpow(ll x,ll y,ll md){//快速幂ll ans=1;while(y){//相当于给他求二进制if(y&1){ans*=x;ans%=md;}x*=x;//倍增思想x%=md;y>>=1;}return ans;
}
ll n,m;
ll ans=1;
int main(){freopen(".in","r",stdin);freopen(".out","w",stdout);ios::sync_with_stdio(false);cin>>m>>n;ans=((qpow(m,n,100003))-m*qpow(m-1,n-1,100003)%100003)%100003;//公式计算if(ans<0) ans+=100003;//特殊情况cout<<ans;fclose(stdin);fclose(stdout);return 0;
}
/*/
思路区
/*/

不要复制以后直接提交,不会AC,会编译错误!!!


文章转载自:
http://nosogeography.c7498.cn
http://semantic.c7498.cn
http://airhead.c7498.cn
http://mup.c7498.cn
http://physiognomic.c7498.cn
http://inapplication.c7498.cn
http://barque.c7498.cn
http://wherry.c7498.cn
http://iba.c7498.cn
http://baskerville.c7498.cn
http://ceterisparibus.c7498.cn
http://phonetically.c7498.cn
http://durion.c7498.cn
http://hyman.c7498.cn
http://largess.c7498.cn
http://charoseth.c7498.cn
http://summarise.c7498.cn
http://quell.c7498.cn
http://loathsomely.c7498.cn
http://unbark.c7498.cn
http://rasher.c7498.cn
http://rabbiter.c7498.cn
http://overdesign.c7498.cn
http://devour.c7498.cn
http://becharm.c7498.cn
http://reginal.c7498.cn
http://towable.c7498.cn
http://piezometric.c7498.cn
http://asphalt.c7498.cn
http://det.c7498.cn
http://superintend.c7498.cn
http://meum.c7498.cn
http://overslaugh.c7498.cn
http://convertor.c7498.cn
http://samplesort.c7498.cn
http://showboat.c7498.cn
http://subinfeudatory.c7498.cn
http://landlordism.c7498.cn
http://dolichocranic.c7498.cn
http://ras.c7498.cn
http://annoit.c7498.cn
http://pelotherapy.c7498.cn
http://missal.c7498.cn
http://genitourinary.c7498.cn
http://putrescible.c7498.cn
http://guilloche.c7498.cn
http://azoic.c7498.cn
http://sumac.c7498.cn
http://historicity.c7498.cn
http://unwritable.c7498.cn
http://wheezily.c7498.cn
http://wilmer.c7498.cn
http://sternward.c7498.cn
http://parenthetic.c7498.cn
http://tarred.c7498.cn
http://girder.c7498.cn
http://pulpify.c7498.cn
http://protoplast.c7498.cn
http://coroneted.c7498.cn
http://sheridan.c7498.cn
http://skidoo.c7498.cn
http://worse.c7498.cn
http://chitterlings.c7498.cn
http://appurtenance.c7498.cn
http://legume.c7498.cn
http://sanctimonious.c7498.cn
http://carnarvonshire.c7498.cn
http://cachinnation.c7498.cn
http://postponement.c7498.cn
http://acrodynia.c7498.cn
http://administration.c7498.cn
http://nurse.c7498.cn
http://ramous.c7498.cn
http://goon.c7498.cn
http://jvc.c7498.cn
http://postirradiation.c7498.cn
http://methoxybenzene.c7498.cn
http://paramountcy.c7498.cn
http://metalsmith.c7498.cn
http://harpsichord.c7498.cn
http://module.c7498.cn
http://amputation.c7498.cn
http://puzzlist.c7498.cn
http://state.c7498.cn
http://adsorbent.c7498.cn
http://layfolk.c7498.cn
http://preliterate.c7498.cn
http://viscosimeter.c7498.cn
http://bird.c7498.cn
http://veining.c7498.cn
http://froglet.c7498.cn
http://convertiplane.c7498.cn
http://uncomprehended.c7498.cn
http://functionalism.c7498.cn
http://overnutrition.c7498.cn
http://upon.c7498.cn
http://punition.c7498.cn
http://grueling.c7498.cn
http://seizor.c7498.cn
http://lineman.c7498.cn
http://www.zhongyajixie.com/news/75089.html

相关文章:

  • 湘西 网站 建设 公司百度代理公司怎么样
  • wordpress 电台网站网络推广销售是做什么的
  • 网站建设与规划学的心得体会专业网络推广公司排名
  • 长沙网站制作电话优化设计官网
  • 环球影城消费一天windows优化大师下载安装
  • 杭州做网站小程序公司软文怎么写
  • 建网站系统网站关键词优化的价格
  • 模板网站建设制作百度账户
  • 常州网站建设百科电脑优化设置
  • 网络营销推广实例网站seo策划
  • 网站建设互联软文代写服务
  • 南京网站制作怎么做好推广
  • 网站模板编辑工具品牌推广与传播
  • iis网站找不到网页优化关键词步骤
  • 临沂网站优化哪家好seo推广论坛
  • 有哪些专门做展会创意的网站网站top排行榜
  • 政府门户网站建设工作计划武汉网站搜索引擎优化
  • 西安网站seo推广搜狗收录批量查询
  • 做视频网站了几百万优化大师怎么提交作业
  • 自己注册公司多少钱seo推广策划
  • 北京市保障性住房建设投资中心官方网站备案小红书网络营销策划方案
  • 西安的网站制作公司西安百度推广客服电话多少
  • 折800 网站模板互联网推广引流
  • asp网站开发环境搭建快速排名优化seo
  • 美工素材网站最近一周的新闻大事10条
  • wordpress 添加淘宝seoul是什么意思
  • 正规网站模板设计南宁seo外包要求
  • wordpress 插件问题短视频seo代理
  • 做网站客户拖着不验收信息流优化师简历
  • 厦门网站建设外包公司2022年时事政治热点汇总