【HDU】5321 Beautiful Set【枚举k求贡献,欧拉函数应用】

2024-09-05 14:08

本文主要是介绍【HDU】5321 Beautiful Set【枚举k求贡献,欧拉函数应用】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

传送门: 【HDU】5321 Beautiful Set

my  code:

#include <stdio.h>
#include <string.h>
#include <vector>
#include <algorithm>
using namespace std ;typedef long long LL ;#define clr( a , x ) memset ( a , x , sizeof a )const int MAXN = 100005 ;
const int mod = 258280327 ;bool prime[MAXN] ;
int phi[MAXN] ;
int cnt[MAXN] ;
int id[MAXN] ;
int f[MAXN] ;
int vf[MAXN] ;
int n ;void exgcd ( int a , int b , int& x , int& y ) {if ( b ) {exgcd ( b , a % b , y , x ) ;y -= a / b * x ;} else x = 1 , y = 0 ;
}int inv ( int a ) {int x , y , b = mod ;exgcd ( a , b , x , y ) ;if ( x < 0 ) x += mod ;return x ;
}int cmp ( int a , int b ) {return cnt[a] > cnt[b] ;
}void calc () {for ( int i = 1 ; i < MAXN ; ++ i ) {id[i] = i ;for ( int j = i + i ; j < MAXN ; j += i ) {cnt[i] += cnt[j] ;}}sort ( id + 1 , id + MAXN , cmp ) ;
}void preprocess () {f[0] = vf[0] = 1 ;for ( int i = 1 ; i < MAXN ; ++ i ) {phi[i] = i ;f[i] = ( LL ) i * f[i - 1] % mod ;vf[i] = inv ( f[i] ) ;}for ( int i = 2 ; i < MAXN ; ++ i ) if ( !prime[i] ) {for ( int j = i ; j < MAXN ; j += i ) {phi[j] = phi[j] / i * ( i - 1 ) ;prime[j] = 1 ;}}
}int c ( int a , int b ) {return ( LL ) f[a] * vf[b] % mod * vf[a - b] % mod ;
}void solve () {int x ;int ans1 = 0 , ans2 = 0 ;clr ( cnt , 0 ) ;for ( int i = 1 ; i <= n ; ++ i ) {scanf ( "%d" , &x ) ;cnt[x] ++ ;}calc () ;for ( int i = 1 ; i < MAXN ; ++ i ) {int tmp = 0 ;for ( int j = 1 ; j < MAXN ; ++ j ) {int idx = id[j] ;if ( cnt[idx] < i ) break ;int t = ( LL ) c ( cnt[idx] , i ) * phi[idx] % mod ;tmp = ( tmp + t ) % mod ;}ans2 = ( ans2 + ( LL ) i * tmp ) % mod ;tmp = ( LL ) tmp * f[i] % mod * f[n - i + 1] % mod ;ans1 = ( ans1 + tmp ) % mod ;}if ( ans1 > ans2 ) printf ( "Mr. Zstu %d\n" , ans1 ) ;else if ( ans1 < ans2 ) printf ( "Mr. Hdu %d\n" , ans2 ) ;else printf ( "Equal %d\n" , ans1 ) ;
}int main () {preprocess () ;while ( ~scanf ( "%d" , &n ) ) solve () ;return 0 ;
}

这篇关于【HDU】5321 Beautiful Set【枚举k求贡献,欧拉函数应用】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139172

相关文章

pandas使用apply函数给表格同时添加多列

《pandas使用apply函数给表格同时添加多列》本文介绍了利用Pandas的apply函数在DataFrame中同时添加多列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、Pandas使用apply函数给表格同时添加多列二、应用示例一、Pandas使用apply函

Nginx内置变量应用场景分析

《Nginx内置变量应用场景分析》Nginx内置变量速查表,涵盖请求URI、客户端信息、服务器信息、文件路径、响应与性能等类别,这篇文章给大家介绍Nginx内置变量应用场景分析,感兴趣的朋友跟随小编一... 目录1. Nginx 内置变量速查表2. 核心变量详解与应用场景3. 实际应用举例4. 注意事项Ng

Python中Namespace()函数详解

《Python中Namespace()函数详解》Namespace是argparse模块提供的一个类,用于创建命名空间对象,它允许通过点操作符访问数据,比字典更易读,在深度学习项目中常用于加载配置、命... 目录1. 为什么使用 Namespace?2. Namespace 的本质是什么?3. Namesp

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

Java枚举类型深度详解

《Java枚举类型深度详解》Java的枚举类型(enum)是一种强大的工具,它不仅可以让你的代码更简洁、可读,而且通过类型安全、常量集合、方法重写和接口实现等特性,使得枚举在很多场景下都非常有用,本文... 目录前言1. enum关键字的使用:定义枚举类型什么是枚举类型?如何定义枚举类型?使用枚举类型:2.

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集