Codeforces 935 简单几何求圆心 DP快速幂求与逆元
A
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-8;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int maxm = ;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll mod = 3e7;
int weight;
int from,to;
vector<pair<int,int> > place[];
int main()
{
int anser=;
int n;
cin >> n;
for(int i=; i<=n; i++)
{
if(n%i==)
anser++;
}
cout<<anser<<endl;
}
B
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-8;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int maxm = ;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll mod = 3e7;
int num[];
int check(int x,int y)
{
if(x==y)
return ;
if(x>y)
return ;
return ;
}
int main()
{
int n;
int anser=;
int nowx,nowy;
nowx=nowy=;
cin >> n;
string a;
cin >> a;
int now=;
int belong=;
for(int i=; i<n; i++)
{
if(a[i]=='U')
nowy++;
else
nowx++;
belong=check(nowx,nowy);
num[i]=belong;
if(i>=)
if(num[i]+num[i-]==)
anser++;
// cout<<i<<" "<<nowx<<" "<<nowy<<endl;
// cout<<anser<<endl;
}
cout<<anser<<endl;
}
C
简单几何 题意题
给你一个圆和一个点,让你在给定圆内画一个圆,使得答案圆不能包含给定点,而且使得给定圆没有被答案圆覆盖的面积最小。输出答案圆的圆心和半径即可。
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-8;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int maxm = ;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll mod = 3e7;
int num[];
int main()
{
double R,x1,x2,y1,y2;
cin >>R >> x1 >> y1 >> x2 >> y2;
double xap,yap,r;
double len=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
double dis1=sqrt(len);
if(len>=R*R)
{
printf("%.7f %.7f %lf",x1,y1,R);
return ;
}
if(x1==x2&&y1==y2)
{
printf("%.7f %.7f %.7f",x1+R/,y1,R/);
return ;
}
r=(R+dis1)/2.0;
xap=x2+(x1-x2)*(r/dis1);
yap=y2+(y1-y2)*(r/dis1);
printf("%.7f %.7f %lf",xap,yap,r);
}
D
给你两个长为N包含0的数字串 0可以变化为1-k的任何数
要求你求出第一个串比第二个大的可能性(一个分数)模上1e9+7
总共的可能性数量很好想 是K的0数量次方 再把分数转化为求逆元就变为:比原串大的方案数乘以 总方案数对MOD的逆元 模MOD
dp[i][0]表示到第i个两个字典序相等的方案数 dp[i][1]表示到第i个第一个比第二个字典序大的方案数
dp[i][1]可以由dp[i-1][0]与dp[i-1][1]转换而来 而 dp[i][0]只能由dp[i-1][0]转换而来
所以分类讨论
1.a=ai b=bi时
相等时
dp[i][0]=dp[i-1][0]
dp[i][1]=dp[i-1][1]
前大于后时
dp[i][1]=dp[i-1][0]+dp[i-1][1]
dp[i][0]=0
后大于前时
dp[i][1]=dp[i][0]=0
2.a=0 b=bi时
dp[i][0]=dp[i-1][0]
dp[i][1]=dp[i-1][1]*k+dp[i-1][0]*(k-bi)
3.a=ai b=0时
dp[i][0]=dp[i-1][0]
dp[i][1]=dp[i-1][1]*k+dp[i-1][0]*(b-1)
4.a=b=0
dp[i][0]=dp[i-1][0]*k
dp[i][1]=dp[i-1][1]*k*k+dp[i-1][0]*(k-1)*k/2
一直dp到n
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-8;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
const int mod = 1e9+;
int sum=;
ll dp[][];
int num[][];
ll quickpow(ll x,ll n)
{
ll res=;
while(n)
{
if(n&)res=res*x%mod;
x=x*x%mod;
n/=;
}
return res;
}
int main()
{
ll n,m;
cin >> n >> m;
for(int i=; i<=; i++)
for(int j=; j<=n; j++)
{
scanf("%d",&num[i][j]);
}
mem(dp,);
dp[][]=;
for(int i=; i<=n; i++)
{
sum+=(num[][i]==);
sum+=(num[][i]==);
if(num[][i]&&num[][i])
{
if(num[][i]==num[][i])
{
dp[i][]=dp[i-][];
dp[i][]=dp[i-][];
}
else if(num[][i]>num[][i])
{
dp[i][]=(dp[i-][]+dp[i-][])%mod;
dp[i][]=;
}
else
{
dp[i][]=;
dp[i][]=dp[i-][];
}
}
else if(num[][i]==&&num[][i]==)
{
dp[i][]=dp[i-][]*m%mod;
dp[i][]=((dp[i-][]*((m*m)%mod)%mod+dp[i-][]*((m-)*m/)%mod)%mod)%mod;
}
else if(num[][i]==)
{
dp[i][]=dp[i-][]%mod;
dp[i][]=(dp[i-][]*m%mod+dp[i-][]*(m-num[][i])%mod)%mod;
}
else if(num[][i]==)
{
dp[i][]=dp[i-][]%mod;
dp[i][]=(dp[i-][]*m%mod+dp[i-][]*(num[][i]-)%mod)%mod;
}
}
ll anser=dp[n][]*quickpow(quickpow(m,sum),mod-)%mod;
cout<<anser<<endl;
}
Codeforces 935 简单几何求圆心 DP快速幂求与逆元的更多相关文章
- Codeforces Round #536 (Div. 2) F 矩阵快速幂 + bsgs(新坑) + exgcd(新坑) + 欧拉降幂
https://codeforces.com/contest/1106/problem/F 题意 数列公式为\(f_i=(f^{b_1}_{i-1}*f^{b_2}_{i-2}*...*f^{b_k} ...
- 【bzoj4870】[Shoi2017]组合数问题 dp+快速幂/矩阵乘法
题目描述 输入 第一行有四个整数 n, p, k, r,所有整数含义见问题描述. 1 ≤ n ≤ 10^9, 0 ≤ r < k ≤ 50, 2 ≤ p ≤ 2^30 − 1 输出 一行一个整数 ...
- codeforce 227E 矩阵快速幂求斐波那契+N个连续数求最大公约数+斐波那契数列的性质
E. Anniversary time limit per test2 seconds memory limit per test256 megabytes inputstandard input o ...
- HDU4869:Turn the pokers(快速幂求逆元+组合数)
题意: 给出n次翻转和m张牌,牌相同且一开始背面向上,输入n个数xi,表示xi张牌翻转,问最后得到的牌的情况的总数. 思路: 首先我们可以假设一开始牌背面状态为0,正面则为1,最后即是求ΣC(m,k) ...
- POJ-3070Fibonacci(矩阵快速幂求Fibonacci数列) uva 10689 Yet another Number Sequence【矩阵快速幂】
典型的两道矩阵快速幂求斐波那契数列 POJ 那是 默认a=0,b=1 UVA 一般情况是 斐波那契f(n)=(n-1)次幂情况下的(ans.m[0][0] * b + ans.m[0][1] * a) ...
- 小白月赛13 小A的路径 (矩阵快速幂求距离为k的路径数)
链接:https://ac.nowcoder.com/acm/contest/549/E来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- hdu 2065 "红色病毒"问题(快速幂求模)
n=1 --> ans = 2 = 1*2 = 2^0(2^0+1) n=2 --> ans = 6 = 2*3 = 2^1(2^1+1) n=3 --> ans = 20 ...
- Product Oriented Recurrence(Codeforces Round #566 (Div. 2)E+矩阵快速幂+欧拉降幂)
传送门 题目 \[ \begin{aligned} &f_n=c^{2*n-6}f_{n-1}f_{n-2}f_{n-3}&\\ \end{aligned} \] 思路 我们通过迭代发 ...
- hdu4686 简单的矩阵快速幂求前n项和
HDU4686 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4686 题意:题目说的很清楚了,英语不好的猜也该猜懂了,就是求一个表达式的前n项和,矩阵 ...
随机推荐
- 《Effective Java》读书笔记 - 3.对于所有对象都通用的方法
Chapter 3 Methods Common to All Objects Item 8: Obey the general contract when overriding equals 以下几 ...
- chrome查看JavaScript的堆栈调用
设置断点之后,查看的时候,注意右侧栏. 在调试按钮下方,有一个watch和call stack,
- iptables添加、删除端口
简洁才是王道, 下面是添加一个udp端口,端口号8566,即接收到8566端口的所有udp包 /sbin/iptables -I INPUT -p udp --dport -j ACCEPT 要删除这 ...
- lambda表达式匿名函数
匿名函数是一个“内联”语句或表达式,可在需要委托类型的任何地方使用.可以使用匿名函数来初始化命名委托,或传递命名委托(而不是命名委托类型)作为方法参数. C# 中委托的发展 在 C# 1.0 中,您通 ...
- RocketMQ 主从同步
RocketMQ 的主和从一直在使用 nio 进行数据同步: master master 监听端口 org.apache.rocketmq.store.ha.HAService.AcceptSocke ...
- 阶段3 1.Mybatis_02.Mybatis入门案例_2.mybatis入门案例中的设计模式分析
读取配合文件 创建工厂 最终图
- 移动端自动化==>AppiumApi接口详解
Appium 初始化配置信息(Desired Capabilities) Desired Capabilities实际上就是一个字典,它主要用于向Appium Server提供初始化配置参数,如:想要 ...
- Python学习之==>URL编码解码&if __name__ == '__main__'
一.URL编码解码 url的编码解码需要用到标准模块urllib中的parse方法 from urllib import parse url = 'http://www.baidu.com?query ...
- DedeCMS系统设置说明:站点设置
DedeCMS系统设置说明:站点设置 http://www.ithov.com/master/114583.shtml DedeCMS系统设置说明:站点设置 2012-03-28 15:31来源:风信 ...
- ElasticSearch入门 —— 集群搭建
一.环境介绍与安装准备 1.环境说明 2台虚拟机,OS为ubuntu13.04,ip分别为xxx.xxx.xxx.140和xxx.xxx.xxx.145. 2.安装准备 ElasticSearch(简 ...