照看小猫(nowcoder 217602)
照看小貓
nowcoder 217602
題目大意
有n只小貓,對(duì)于第i只小貓,給它取一個(gè)以小寫字母組成的名字(長(zhǎng)度不大于aia_iai?),問你使所有小貓名字不同的方案數(shù)
樣例#1
輸入樣例#1
1 1輸出樣例#1
26樣例解釋#1
貓咪的名字可以為 a-z 間的任意一個(gè)字母,所以方案數(shù)為 26。
樣例#2
輸入樣例#2
1 2輸出樣例#2
702樣例解釋#2
貓咪的名字的長(zhǎng)度可以為 1,也可以為 2。
長(zhǎng)度為 1 時(shí),名字可以為 a-z 中任意一個(gè),方案數(shù) 26 種。
長(zhǎng)度為 2 時(shí),名字可以為 aa-az, ba-bz ,…,za-zz 中任意一個(gè),方案數(shù) 26×26=676種。
所以總方案數(shù)為 26+676=702 種。
樣例#3
輸入樣例#3
5 7 5 8 4 3輸出樣例#3
9416數(shù)據(jù)范圍
1?N?104,q?101\leqslant N \leqslant 10^4,q\leqslant 101?N?104,q?10
解題思路
對(duì)于第k只小貓,名字有j位的方案數(shù)是26k26^k26k
那么方案總數(shù)為:∑k=1ai26k\sum_{k=1}^{a_i}26^k∑k=1ai??26k
對(duì)于aj>aia_j>a_iaj?>ai?,第j只小貓選的名字不一定在當(dāng)前小貓的方案總數(shù)中
而對(duì)于aj<aia_j<a_iaj?<ai?,第j只小貓選的名字一定在當(dāng)前小貓的方案總數(shù)中
所以可以按a從小到大排序
當(dāng)計(jì)算第i只小貓的方案總數(shù)時(shí),減去a值比i小的個(gè)數(shù)
因?yàn)檫@些貓選的方案已定會(huì)使i的方案總數(shù)-1
計(jì)算完所有小貓的種數(shù)后,乘在一起即可
代碼
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define ll long long #define wyc 77797 using namespace std; ll n, g, ans, a[10010], pw[15]; int main() {scanf("%lld", &n);for (int i = 1; i <= n; ++i)scanf("%lld", &a[i]);sort(a + 1, a + 1 + n);//排序pw[1] = 26;for (int i = 2; i <= 10; ++i){pw[i] = pw[i - 1] * 26;//預(yù)處理總方案數(shù)pw[i - 1] += pw[i - 2];}pw[10] += pw[9];ans = 1;for (int i = 1; i <= n; ++i){g = pw[a[i]] - i + 1;//減去沖突的if (g < 0)//方案數(shù)小于0,說明沒有可行的方案{printf("-1");return 0;}g %= wyc;ans = ans * g % wyc;}printf("%lld", ans);return 0; } 創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的照看小猫(nowcoder 217602)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 居家客服兼职需要准备什么居家客服兼职需要
- 下一篇: win10系统如何切换独立显卡如何设置电