牛客练习赛52

C 烹饪

链接:https://ac.nowcoder.com/acm/contest/1084/C来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld

题目描述

“你已经是一个成熟的孩子了,要学会自己烹饪了!”

小 Y 上山拜师学艺,经过 年之长的厨艺练习,已成为当世名厨,今天他接受邀请,在众人面前展示自己高超的厨艺。

人们给小 Y 提供了 种食物,每种食物无限量供应,每种食物都有一个美味值,记为 aia_iai​。

小 Y 为了展示他的厨艺,他需要挑选出食材,使自己可以烹饪出任意正整数美味值的菜肴,初始时菜肴的美味值为 每次加入一种食材,他可以选择让菜肴的美味值上升 aia_iai​,也可以选择让菜肴的美味值下降 aia_iai​(或许最后会弄出来黑暗料理?)。

作为当世名厨,小 Y 自然知道该怎么挑选食材最佳。可是他并不知道有多少种最佳的挑选食材方案,于是他找到了你来帮忙。

我们使用无序数列(b1,b2,…,bm)(b_1,b_2,\ldots,b_m)(b1,b2,…,bm)来表示从原来的n种食材中挑选出了m种食材,第i种食材编号为bib_ibi的方案。同时你需要注意,为同一种方案且当i≠ji \not =ji=j时,bi≠bjb_i \not = b_jbi=bj。

最佳的挑选食材方案指,挑选出 食材(1≤m≤n1\leq m\leq n1≤m≤n),让他们能够组合出任意正整数美味值的菜肴

例如,当n=2,a1=1,a2=2n=2,a_1=1,a_2=2n=2,a1=1,a2=2时,(1),(1,2)\left( 1\right),\left( 1,2\right)(1),(1,2)都是最佳的挑选食材方案

答案对 取模。

输入描述:

第一行一个正整数 。第二行 个正整数 ai(1≤ai≤2 000)a_i(1\le a_i\le2\ 000)ai(1≤ai≤2 000)。

输出描述:

输出一个数表示最佳的挑选食材方案的数量对 取模。

示例1

输入

复制

5
1 2 3 4 5

输出

复制

26

示例2

输入

复制

1
2

输出

复制

0

思路:

有一个结论十分显然,即能组合出[1,n][1,n][1,n]的任意正整数的充要条件时能组成1

根据裴蜀定理ax+by=gcd(a,b),显然这扩展到n元组也成立

于是问题转换成为:选出一个集合,集合中每个数可以选多次,并且这个集合gcd为1,

设f[i]表示组成集合gcd为i的方案数

显然f[gcd(x,j)]=∑f[j]

注意方案多算了一倍,除以二就行了

于是O(nmlogm)解决了

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define sz(a) int(a.size())
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl
#define du3(a,b,c) scanf("%d %d %d",&(a),&(b),&(c))
#define du2(a,b) scanf("%d %d",&(a),&(b))
#define du1(a) scanf("%d",&(a));
using namespace std;
typedef long long ll;
ll gcd(ll a, ll b) {return b ? gcd(b, a % b) : a;}
ll lcm(ll a, ll b) {return a / gcd(a, b) * b;}
ll powmod(ll a, ll b, ll MOD) {a %= MOD; if (a == 0ll) {return 0ll;} ll ans = 1; while (b) {if (b & 1) {ans = ans * a % MOD;} a = a * a % MOD; b >>= 1;} return ans;}
void Pv(const vector<int> &V) {int Len = sz(V); for (int i = 0; i < Len; ++i) {printf("%d", V[i] ); if (i != Len - 1) {printf(" ");} else {printf("\n");}}}
void Pvl(const vector<ll> &V) {int Len = sz(V); for (int i = 0; i < Len; ++i) {printf("%lld", V[i] ); if (i != Len - 1) {printf(" ");} else {printf("\n");}}}inline void getInt(int* p);
const int maxn = 1000010;
const int inf = 0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
const ll mod = 998244353ll;ll f[maxn];
ll a[maxn];int n;int main()
{//freopen("D:\\code\\text\\input.txt","r",stdin);//freopen("D:\\code\\text\\output.txt","w",stdout);gbtb;cin >> n;repd(i, 1, n){cin >> a[i];}repd(i, 1, n){f[a[i]]++;repd(j, 1, 2000){ll x = gcd(a[i], j);f[x] += f[j];f[x] %= mod;}}cout << f[1]*powmod(2, mod - 2ll, mod) % mod << endl;return 0;
}inline void getInt(int* p) {char ch;do {ch = getchar();} while (ch == ' ' || ch == '\n');if (ch == '-') {*p = -(getchar() - '0');while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 - ch + '0';}}else {*p = ch - '0';while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 + ch - '0';}}
}

转载于:https://www.cnblogs.com/qieqiemin/p/11633119.html

牛客练习赛52 | C | [烹饪] (DP,裴蜀定理,gcd)相关推荐

  1. 牛客练习赛52 B.Galahad (树状数组)

    B.Galahad 链接:https://ac.nowcoder.com/acm/contest/1084/B 来源:牛客网 题目描述 魔女要测试骑士的能力,要求他维护一个长度为 的序列,每次要询问一 ...

  2. 牛客练习赛52.Galahad(树状数组维护区间不相同数的和)

    链接:https://ac.nowcoder.com/acm/contest/1084/B 来源:牛客网 Galahad 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K ...

  3. 牛客练习赛52 B Galahad (树状数组)

    题目链接:https://ac.nowcoder.com/acm/contest/1084/B 题意 5e5的区间,5e5个询求[l,r]区间内出现过的数的和 思路 1s时限,莫队显然会T 我们可以将 ...

  4. 牛客练习赛52 BGalahad 树状数组

    传送门 题意: 求一个区间的和,但如果某一个数在这个区间出现了多次,这个数只能被计算一次. 官方题解:按右端点从小到大排序.建立树状数组ccc,维护贡献的前缀和. 由于权值ai 满足1≤ai≤500  ...

  5. 牛客练习赛52 B:Galahad(树状数组维护区间不同元素和(个数))

    [题目] 查询区间和,如果区间元素重复出现则计数一次. [题解] 按区间的右端点建立树状数组,维护区间[1,R]的每个元素的最右位置.按查询区间的右端点排序,依次处理,每次更新当前值的最右位置即可. ...

  6. 牛客练习赛34 E little w and Digital Root(数位dp)

    title: 牛客练习赛34 E little w and Digital Root(数位dp) date: 2018-12-17 22:38:37 tags: 数位dp categories:ACM ...

  7. 牛客练习赛29 题解

    牛客练习赛29 A. 可持久化动态图上树状数组维护01背包 题解 这题跟标题没有任何关系- 贪心的使得负数删除的时候下标尽可能大,然后正数的时候下标尽可能小. 观察到每个数下标最大的时候就是它的初始下 ...

  8. 牛客练习赛81 E. 小 Q 与函数求和 1( “简单莫比乌斯反演” ,欧拉函数性质)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 牛客练习赛81 E. 小 Q 与函数求和 1( "简单莫比乌斯反演" ) Prob ...

  9. 解题报告(一)C、(牛客练习赛41 F)简单数学题(数论 + FWT)(3.5)

    繁凡出品的全新系列:解题报告系列 -- 超高质量算法题单,配套我写的超高质量题解和代码,题目难度不一定按照题号排序,我会在每道题后面加上题目难度指数(1∼51 \sim 51∼5),以模板题难度 11 ...

最新文章

  1. 公开课:如何成为一名高级系统运维工程师(架构师)?
  2. 物理理论发展放缓?这是一种认知误判
  3. TEG六周年 | 同心筑梦 共赢未来
  4. eas 在linux下安装_linux下easy_install的安装与使用详解
  5. Reflection.Emit的使用场景、工具包及示例总结
  6. 阿里云部署Docker(5)----管理和公布您的镜像
  7. UDP打洞NAT大致分为下面四类 P2P
  8. libSVM介绍(二)
  9. java coherence_Coherence配置默认覆盖路径
  10. 【总结】大端、小端存储模式的那点事
  11. matlab2020面板介绍
  12. JAVA 获取文件指纹
  13. OverTheWire的bandit游戏(11-20)
  14. Javasctipt面试题整理
  15. MYSQL简单题目和知识点
  16. 9.2. switchport trunk encapsulation dot1q 提示 invaild input at^marker.
  17. php一句话上传webshell,一句话shell,哪些是恶意的php一句话webshell
  18. (附源码)spring boot网上购物系统 毕业设计 311236
  19. 76%都存在漏洞?!Docker镜像安全扫描应该这样做
  20. win10 取消任务栏图标合并

热门文章

  1. CRM Fiori Opportunity应用点了edit之后超时的问题分析
  2. Linux Ubuntu终端“@”前后的含义及修改(修改用户名及主机名)【试用办法,部分不可行】
  3. 字典树-01字典树基础
  4. docker mysql 防火墙_docker mysql
  5. datagridview滚动条自动滚动_微软新贡献:进一步优化Chromium的滚动特性
  6. kylin 部分问题
  7. 人才管理是什么意思_cms系统是什么意思,国内常用的cms内容管理系统有哪些
  8. 江苏单招计算机网络试卷,江苏省2016年对口单招计算机专业综合理论试卷.doc
  9. rapidjson读取json文件_SPARK入门 - json文件读取
  10. random_state的值如何选_同样是防晒衣,单价几十和几百块有什么不同?选防晒衣认准这4点...