[CSP-S模拟测试]:小盆友的游戏(数学 or 找规律)

题目传送门(内部题110)


输入格式

  第一行一个整数$N$,表示小盆友的个数。
  第二行$N$个整数$A_i$,如果$A_i=-1$表示$i$目前是自由身,否则$i$是$A_i$的跟班。


输出格式

  一个整数$X$,表示在模$10^9+7$的情况下,期望总猜拳次数。


样例

样例输入1:

2
-1 -1

样例输出1:

1

样例输入2:

3
-1 -1 -1

样例输出2:

3

样例输入3:

4
-1 -1 -1 -1

样例输出3:

7

样例输入4:

5
-1 -1 -1 -1 -1

样例输出4:

15

样例输入5:

3
-1 -1 2

样例输出5:

2

样例输入6:

4
-1 -1 2 2

样例输出6:

4


数据范围与提示

样例$1$解释:

  无论谁输谁赢,一次猜拳后,一个人就成为另外一个人的跟班,那另外一个人则胜出,游戏结束。

数据范围:

  对于$10\%$的数据,满足$n=1$。
  对于$50\%$的数据,满足$n\leqslant 1,000,A_i=-1$。
  对于$100\%$的数据,满足$n\leqslant 100,000$。


题解

样例给这么多,而且还是第一题,一看就是给找规律的;不过为什么出题人不给个类似下面这样的样例?

4
-1 -1 1 2

其实答案就是:

$$ans=2^{(n-1)}-1-(\sum \limits_{i=1}^n2^{(sum[i]-1)}-1)$$

其中$sum[i]$表示$i$的跟班个数。

时间复杂度:$\Theta(n+\log n)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
const int mod=1000000007;
int n;
int sum[100001];
long long ans;
long long qpow(long long x,long long y)
{
	long long res=1;
	while(y)
	{
		if(y&1)res=res*x%mod;
		x=x*x%mod;
		y>>=1;
	}
	return res;
}
int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++){int x;scanf("%d",&x);if(x!=-1)sum[x]++;}
	ans=qpow(2,n-1)-1;
	for(int i=1;i<=n;i++)
		ans=(ans-qpow(2,sum[i])+1+mod)%mod;
	printf("%lld",ans);
	return 0;
}


rp++

原文地址:https://www.cnblogs.com/wzc521/p/11779046.html

时间: 2024-08-14 21:06:01

[CSP-S模拟测试]:小盆友的游戏(数学 or 找规律)的相关文章

[CSP-S模拟测试]:小W的魔术(数学 or 找规律)

题目传送门(内部题130) 输入格式 第一行一个整数$n$,表示字符串的长度. 第二行一个只包含小写字母的字符串$s$. 输出格式 一行一个整数表示答案对$998244353$取模后的结果. 样例 样例输入: 2a 样例输出: 625 数据范围与提示 对于$20\%$的测试数据,$n\leqslant 4$. 对于$40\%$的测试数据,$n\leqslant 100$. 对于$60\%$的测试数据,$n\leqslant 10,000,000$. 对于另外$20\%$的测试数据,保证$s$只由

[CSP-S模拟测试]:小P的生成树(数学+Kruskal)

题目描述 小$P$是个勤于思考的好孩子,自从学习了最大生成树后,他就一直在想:能否将边权范围从实数推广到复数呢?可是马上小$P$就发现了问题,复数之间的大小关系并没有定义.于是对于任意两个复数$z_1,z_2$,小$P$定义$z_1<z_2$当且仅当$|z_1|<|z_2|$. 现在,给出一张$n$个点$m$条边的简单无向带权图,小$P$想问你,如果按照他对复数大小的定义,这个图的最大生成树是什么? 输入格式 输入的第一行为两个正整数$n$和$m$,分别表示这个无向图的点数和边数. 接下来$m

小盆友给谷歌写封信 老爸获一周假期

多亏了自己的宝贝女儿,一位Google员工在今年夏天得到了一星期福利假期. 这位小盆友给互联网大巨头写了一封信,请求公司在她爸爸生日那天给他放一天假庆祝生日. 「各位大哥哥大姐姐你们好」小盆友的信上写到「我能帮爸爸请个假吗?每星期他都只有星期六放假,但我想让他星期三也能休息.」而星期四这封信已经在 twitter 上传疯了. 「P.S. 因为周三是爸爸生日!」信尾附加到. 顿时,这间公司觉得自己不仅仅有义务这么做,而且被萌得甘之如饴. 「小可爱,谢谢你的贴心提醒」Google 给小盆友回复「你爸

文成小盆友python-num3 集合,函数,-- 部分内置函数

本接主要内容: set -- 集合数据类型 函数 自定义函数 部分内置函数 一.set 集合数据类型 set集合,是一个无序且不重复的元素集合 集合基本特性 无序 不重复 创建集合 #!/bin/env python s1 = {"1","2","3","4"} ##或者 s2 = set() set 提供的功能 1 class set(object): 2 """ 3 set() -> n

文成小盆友python-num9 socket编程

socket编程 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket. Socket的英文原义是“孔”或“插座”.作为BSD UNIX的进程通信机制,取后一种意思.通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信.在Internet上的主机一般运行了多个服务软件,同时提供几种服务.每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务.Socket正如其英文原意那

文成小盆友python-num4 内置函数

一 .python 内置函数补充 chr()  -- 返回所给参数对应的 ASCII 对应的字符,与ord()相反 # -*- coding:utf-8 -*- # Author:wencheng.zhao a = chr(65) print(a) b = chr(66) print(b) ##输出如下: A B Process finished with exit code 0 ord --返回所给的值在ASCII中对应的数字,与chr()作用相反 # -*- coding:utf-8 -*-

文成小盆友python-num5 -装饰器回顾,模块,字符串格式化

一.装饰器回顾与补充 单层装饰器: 如上篇文章所讲单层装饰器指一个函数用一个装饰器来装饰,即在函数执行前或者执行后用于添加相应的操作(如判断某个条件是否满足). 具体请见如下: 单层解释器 双层解释器 双层解释器在原理上相同,只是在执行时比单层复杂.见如下实例: 需求: 做一个简单的登录展示,有两个菜单即可一个菜单仅需要登录后就能查看,一个菜单不但需要登录,而且还得需要是超级管理员登录才能查看. 分析:1.可以写一个装饰器,在着一个装饰器中判断是否满足两个条件如果满足着执行函数体,但问题是还有一

文成小盆友python-num6 -反射 ,常用模块

本次主要内容: 内容补充 python中的反射 常用模块 一,内容补充: 利用上次说到的递归的方法来实现阶乘. 说明:利用函数递归的方法来实现阶乘如: 1*2*3*4*5*6*7 代码实现如下: 1 def fuck(num): 2 if num == 1 or num == 0: #这里直接把等于0的情况也写到这里了. 3 return 1 4 return num * fuck(num - 1) #这里用到了递归 5 6 res = fuck(7) 7 print(res) 8 # 9 #显

文成小盆友python-num2 数据类型、列表、字典

一.先聊下python的运行过程 计算机是不能够识别高级语言的,所以当我们运行一个高级语言程序的时候,就需要一个“翻译机”来从事把高级语言转变成计算机能读懂的机器语言的过程.这个过程分成两类,第一种是编译,第二种是解释.编译型语言在程序执行之前,先会通过编译器对程序执行一个编译的过程,把程序转变成机器语言.运行时就不需要翻译,而直接执行就可以了.最典型的例子就是C语言.解释型语言就没有这个编译的过程,而是在程序运行的时候,通过解释器对程序逐行作出解释,然后直接运行,最典型的例子是Ruby. 当p