CF 300C - Beautiful Numbers [组合数求模]


数学是硬伤。

分析题目后知道就是求sigma(C[i,n]%mod)

1 ≤ n ≤ 106


下面有两种方法,

一、预处理出阶乘,直接根据组合数公式 C[i,n] = n!/( i!*(n-i)! ),由于涉及到除法取模,所以要求下逆元。

62ms.

#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<string>
#include<vector>
#include<map>
#include<algorithm>
using namespace std;
inline int Rint() { int x; scanf("%d", &x); return x; }
inline int max(int x, int y) { return (x>y)? x: y; }
inline int min(int x, int y) { return (x<y)? x: y; }
#define FOR(i, a, b) for(int i=(a); i<=(b); i++)
#define FORD(i,a,b) for(int i=(a);i>=(b);i--)
#define REP(x) for(int i=0; i<(x); i++)
typedef long long int64;
#define INF (1<<30)
const double eps = 1e-8;
#define bug(s) cout<<#s<<"="<<s<<" "

// a,b,n
// 1 ≤ a < b ≤ 9, 1 ≤ n ≤ 10^6
#define MAXN 1000000
#define MOD 1000000007

int a, b;
int64 fact[MAXN+2];

int isgood(int x) {
	for(; x; x/=10) {
		if(x%10 != a && x%10 != b) {
			return 0;
		}
	}
	return 1;
}
void calc_fact() {
	fact[0] = 1;
	FOR(i, 1, MAXN) {
		fact[i] = fact[i-1]*i%MOD;
	}
}

void ext_gcd(int64 a, int64 b, int64& d, int64& x, int64& y)
{
	if(!b) { d = a; x = 1; y = 0; }
	else { ext_gcd(b, a%b, d, y, x); y-=x*(a/b); }
}

int64 inv_mod(int64 a)	// ix=1(mod n)
{
	int64 x, y, d;
	ext_gcd(a, MOD, d, x, y);
	while(x<0) { x+=MOD; }
	return x;
}

int64 C(int k, int n) {
	return fact[n]*inv_mod(fact[k]*fact[n-k])%MOD;
}

int main() {
	a = Rint();
	b = Rint();
	int n = Rint();

	calc_fact();

	int64 ans = 0;
	FOR(i, 0, n) {
		if(isgood(a*i+b*(n-i))) {
			ans = (ans + C(i,n))%MOD;
		}
	}
	printf("%lld\n", ans);
}


二、根据递推公式 c[i]=c[i-1]*(n-i+1)/i ,先递推出所有C[n, i],因为这题n不会变,所以可以这样。同样要为 i 求逆元。

531ms

#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<string>
#include<vector>
#include<map>
#include<algorithm>
using namespace std;
inline int Rint() { int x; scanf("%d", &x); return x; }
inline int max(int x, int y) { return (x>y)? x: y; }
inline int min(int x, int y) { return (x<y)? x: y; }
#define FOR(i, a, b) for(int i=(a); i<=(b); i++)
#define FORD(i,a,b) for(int i=(a);i>=(b);i--)
#define REP(x) for(int i=0; i<(x); i++)
typedef long long int64;
#define INF (1<<30)
const double eps = 1e-8;
#define bug(s) cout<<#s<<"="<<s<<" "

// a,b,n
// 1 ≤ a < b ≤ 9, 1 ≤ n ≤ 10^6
#define MAXN 1000000
#define MOD 1000000007

int a, b;

int isgood(int x) {
	for(; x; x/=10) {
		if(x%10 != a && x%10 != b) {
			return 0;
		}
	}
	return 1;
}

void ext_gcd(int64 a, int64 b, int64& d, int64& x, int64& y)
{
	if(!b) { d = a; x = 1; y = 0; }
	else { ext_gcd(b, a%b, d, y, x); y-=x*(a/b); }
}

int64 inv_mod(int64 a)	// ix=1(mod n)
{
	int64 x, y, d;
	ext_gcd(a, MOD, d, x, y);
	while(x<0) { x+=MOD; }
	return x;
}

// int64 C(int k, int n) {
// 	return fact[n]*inv_mod(fact[k]*fact[n-k])%MOD;
// }

// #define MAXN 10000002
int64 c[MAXN+2];

int64 C(int64 n, int64 k)		//C n k			
{
	c[0] = 1;
	for(int64 i=1; i<=k; i++)
	{
		c[i] = c[i-1]*(n-i+1)%MOD*inv_mod(i) % MOD;
	}
	return c[k];
}

int main() {
	a = Rint();
	b = Rint();
	int n = Rint();

	// calc_fact();

	C(n, n);

	int64 ans = 0;
	FOR(i, 0, n) {
		if(isgood(a*i+b*(n-i))) {
			ans = (ans + c[i])%MOD;
		}
	}
	printf("%lld\n", ans);
}


另,感觉我的求逆元的代码是不是挫了点,好像以前写组合数学的题跑的时间都比别人久。。

数学推理现在完全记不起来了。。还有什么Lucas也不会。。T-T

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值