喵哈哈村的魔法考试 Round #11 (Div.2) 题解
喵哈哈村的星星与月亮(一)
打表发现答案就等于a*b%mod
注意a*b可能爆longlong
#include<bits/stdc++.h>
using namespace std;
const int mod = 1e9+7;
int main(){
long long a,b,c;
while(cin>>a>>b>>c){
cout<<((a%mod)*(b%mod))%mod<<endl;
}
}
喵哈哈村的星星与月亮(二)
数据范围只有10,所以直接dfs就好了。
直接枚举每个点的颜色,然后O(m)去check就好了。
理论复杂度最大是n^n*m,但实际上不会这么大。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 25;
int n,m,mp[maxn][maxn],Mx=0;
int ty[maxn];
vector<int> E[maxn],P;
int FF = 0;
vector<int> D;
int ti = 0;
int vis[maxn];
int T = 0;
void dfs2(int x,int y){
if(FF)return;
if(x==n+1){
FF = 1;
return;
}
for(int i=1;i<=min(x,y);i++){
ty[x]=i;
int flag = 0;
for(int j=1;j<x;j++){
if(mp[x][j]==1&&ty[x]==ty[j]){
flag = 1;
break;
}
}
if(flag == 0)
dfs2(x+1,y);
}
}
int main(){
srand(772003);
while(scanf("%d%d",&n,&m)!=EOF){
memset(mp,0,sizeof(mp));
for(int i=0;i<maxn;i++)E[i].clear();
for(int i=1;i<=m;i++){
int a,b;
scanf("%d%d",&a,&b);
E[a].push_back(b);
E[b].push_back(a);
mp[a][b]=1;
mp[b][a]=1;
}
Mx = 1;
int l = 1,r = n;
int ans = n;
for(int i=Mx;i<=n;i++){
ti = 0;
FF = 0;
dfs2(1,i);
if(FF){
cout<<i<<endl;
break;
}
}
}
}
喵哈哈村的星星与月亮(三)
这道题实际上和[BZOJ 4004][JLOI2015]装备购买 一模一样。
将wi排序,然后从大到小插入就好了,如果插入还是线性无关的就插入,否则就不插入。
用拟阵可以证明贪心的正确性。
然后我们用高斯消元来判断是否线性无关即可。
#include <bits/stdc++.h>
#define maxn 510
using namespace std;
typedef long long ll;
//const int mod = 998224353;
int mod;
struct Node{
int a[maxn], c;
bool operator<(const Node& k)const{return c > k.c;}
}p[maxn], bases[maxn];
bool bases_flag[maxn];
int n, m;
ll power_mod(ll a, ll b, ll mod){
ll ret = 1;
while(b){
if(b & 1)ret = ret * a % mod;
b >>= 1;
a = a * a % mod;
}return ret;
}
void Gauss(Node& a, const Node& b, int o){
//t = a.a[o] / b.b[o]
ll t = mod - a.a[o] * power_mod(b.a[o], mod-2, mod) % mod;
for(int i = o; i <= m; i ++)
a.a[i] =(a.a[i] + b.a[i] * t) % mod;
}
bool Insert(int pos){
for(int i = 1; i <= m; i ++){
if(p[pos].a[i]){
if(!bases_flag[i]){
bases[i] = p[pos];
bases_flag[i] = true;
return true;
}
Gauss(p[pos], bases[i], i);
}
}
return false;
}
int main(){
while(scanf("%d%d%d", &n, &m, &mod)!=EOF){
memset(bases,0,sizeof(bases));
memset(bases_flag,0,sizeof(bases_flag));
for(int i = 1; i <= n; i ++){
for(int j = 1; j <= m; j ++)
scanf("%d", &p[i].a[j]);
scanf("%d", &p[i].c);
}
sort(p+1, p+1+n);
long long ans = 0;
for(int i = 1; i <= n; i ++)
if(Insert(i))ans += p[i].c;
printf("%lld\n", ans);
}
return 0;
}
喵哈哈村的星星与月亮(四)
假设三个数能够构成等比数列的话,那么满足:
ac=bb,满足 a<b,b<c(都相同的另外考虑)
我们发现其实b的因子个数只有logn个,那么b^2的因子个数,实际上也不会很多,所以我们直接暴力的把b*b且小于b的因子个数暴力dfs出来就好了。
然后我们枚举b就可以算答案了。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e6+7;
int a[maxn];
int num[100005],n;
vector<int> E[maxn],P[maxn],N[maxn];
void dfs(int x,int st,int Num){
E[x].push_back(Num);
for(int j=st;j<P[x].size();j++){
int now = Num;
for(int k=1;k<=N[x][j]*2;k++){
now*=P[x][j];
if(now>x)break;
dfs(x,j+1,now);
}
}
}
int main(){
for(int i=1;i<=100000;i++){
int x = i;
for(int j=2;j*j<=i;j++){
if(x%j==0){
P[i].push_back(j);
N[i].push_back(0);
while(x%j==0){
N[i][N[i].size()-1]++;
x/=j;
}
}
}
if(x!=1){
P[i].push_back(x);
N[i].push_back(1);
}
dfs(i,0,1);
sort(E[i].begin(),E[i].end());
E[i].erase(unique(E[i].begin(),E[i].end()),E[i].end());
}
while(scanf("%d",&n)!=EOF){
memset(num,0,sizeof(num));
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
num[a[i]]++;
}
long long ans = 0;
for(int i=1;i<=100000;i++){
if(num[i]>=3){
ans = ans + 1ll*(num[i]-2)*(num[i]-1)*num[i]/6LL;
}
for(int j=0;j<E[i].size();j++){
if(i==E[i][j])continue;
if(1ll*i*i%E[i][j]!=0)continue;
if(1ll*i*i/E[i][j]<=100000){
int p = 1ll*i*i/E[i][j];
ans = ans + 1ll * num[i]*num[E[i][j]]*num[p];
}
}
}
cout<<ans<<endl;
}
}
喵哈哈村的星星与月亮(五)
这道题是离线树状数组。
询问,如果只有A数组的话,实际上就是权值线段树或者主席树的裸题了。
那么我们其实只要将询问按照A数组从小到大排序,然后依次删除对于>A不合法的,然后用个权值树状数组去查询,就可以了。
细节比较多,所以还是看代码吧。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5+7;
int n,q,d[maxn],ans[maxn],All=0;
struct node{
int first,second;
}a[maxn];
bool cmp(node A,node B){
return A.first<B.first;
}
struct Node{
int first,secondfirst,secondsecond;
}query[maxn];
bool cmp2(Node A,Node B){
return A.first<B.first;
}
inline bool scan_d(int &num)
{
char in;bool IsN=false;
in=getchar();
if(in==EOF) return false;
while(in!='-'&&(in<'0'||in>'9')) in=getchar();
if(in=='-'){ IsN=true;num=0;}
else num=in-'0';
while(in=getchar(),in>='0'&&in<='9'){
num*=10,num+=in-'0';
}
if(IsN) num=-num;
return true;
}
int lowbit(int x){
return x&(-x);
}
void update(int x,int v){
for(int i=x;i<maxn;i+=lowbit(i)){
d[i]+=v;
}
}
int getsum(int x){
int ans = 0;
for(int i=x;i;i-=lowbit(i))
ans+=d[i];
return ans;
}
int main(){;
while(scanf("%d%d",&n,&q)!=EOF){
memset(d,0,sizeof(d));
memset(ans,0,sizeof(ans));
All=0;
for(int i=1;i<=n;i++)
scan_d(a[i].first);
for(int i=1;i<=n;i++){
scan_d(a[i].second);
All++;
update(a[i].second,1);
}
for(int i=1;i<=q;i++){
scan_d(query[i].first);
scan_d(query[i].secondfirst);
query[i].secondsecond=i;
}
sort(a+1,a+1+n,cmp);
sort(query+1,query+1+q,cmp2);
int tot = 1;
for(int i=1;i<=q;i++){
while(tot<=n&&a[tot].first<query[i].first){
update(a[tot].second,-1);
All--;
tot++;
}
ans[query[i].secondsecond]=All-getsum(query[i].secondfirst-1);
}
for(int i=1;i<=q;i++){
printf("%d\n",ans[i]);
}
}
return 0;
}
喵哈哈村的魔法考试 Round #11 (Div.2) 题解的更多相关文章
- 喵哈哈村的魔法考试 Round #2 (Div.2) 题解
喵哈哈村的魔法考试 Round #2 (Div.2) 题解 A.喵哈哈村的战争 题解: 这道题就是for一遍,统计每个村子的战斗力的和,然后统计哪个村子的战斗力和大一点就好了. 唯一的坑点,就是这道题 ...
- 喵哈哈村的魔法考试 Round #1 (Div.2) 题解
喵哈哈村的魔法考试 Round #1 (Div.2) 题解 特别感谢出题人,qscqesze. 也特别感谢测题人Xiper和CS_LYJ1997. 没有他们的付出,就不会有这场比赛. A 喵哈哈村的魔 ...
- 喵哈哈村的魔法考试 Round #7 (Div.2) 题解
喵哈哈村的魔法考试 Round #7 (Div.2) 注意!后四道题来自于周日的hihocoder offer收割赛第九场. 我建了个群:欢迎加入qscoj交流群,群号码:540667432 大概作为 ...
- 喵哈哈村的魔法考试 Round #1 (Div.2) 题解&源码(A.水+暴力,B.dp+栈)
A.喵哈哈村的魔法石 发布时间: 2017年2月21日 20:05 最后更新: 2017年2月21日 20:06 时间限制: 1000ms 内存限制: 128M 描述 传说喵哈哈村有三种神 ...
- 喵哈哈村的魔法考试 Round #19 (Div.2) 题解
题解: 喵哈哈村的魔力源泉(1) 题解:签到题. 代码: #include<bits/stdc++.h> using namespace std; int main(){ long lon ...
- 喵哈哈村的魔法考试 Round #14 (Div.2) 题解
喵哈哈村的四月半活动(一) 题解: 唯一的case,就是两边长度一样的时候,第三边只有一种情况. #include <iostream> #include <cstdio> # ...
- 喵哈哈村的魔法考试 Round #8 (Div.2) 题解
喵哈哈村的美食面馆 签到题,就不停的if就好了. #include<bits/stdc++.h> using namespace std; string name[5]={"ni ...
- 喵哈哈村的魔法考试 Round #4 (Div.2) 题解
有任何疑问,可以加我QQ:475517977进行讨论. A 喵哈哈村的嘟嘟熊魔法(1) 题解 这道题我们只要倒着来做就可以了,因为交换杯子是可逆的,我们倒着去模拟一遍就好了. 有个函数叫做swap(a ...
- 喵哈哈村的魔法考试 Round #20 (Div.2) 题解
题解: A 喵哈哈村的跳棋比赛 题解:其实我们要理解题意就好了,画画图看看这个题意.x<y,那么就交换:x>y,那么x=x%y. 如果我们经过很多次,或者y<=0了,那么就会无限循环 ...
随机推荐
- navicat报caching_sha2_password异常
使用navicat连接mysql报错(升级到mysql8版本时的错) 解决办法: 通过命令行登录mysql后, 输入: alter user 'root'@'localhost' IDENTIFIED ...
- 基于Apache的阿里云部署Node.js服务器(Windows环境)
1 前言 由于nodejs项目对方开放了多个端口,而且阿里云上的Apache服务器(windows)已经挂载了网站,此时需要把此项目也挂上去,网上查询资料,方法略少,基本是基于nginx版本的. 2 ...
- ajax post 传递数组参数
1.前言 此文章仅作为记录,方便查阅. 2.代码 javascript: var idArr = ['one','two','Three']; $.ajax({ type: 'POST', data ...
- [转]清理ambari安装的hadoop集群
本文针对redhat或者centos 对于测试集群,如果通过ambari安装Hadoop集群后,想重新再来一次的话,需要清理集群. 对于安装了很多hadoop组件的话,这个工作很繁琐.接下来是我整理的 ...
- LeetCode(55): 跳跃游戏
Medium! 题目描述: 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1, ...
- poj3067 二维偏序树状数组
题解是直接对一维升序排列,然后计算有树状数组中比二维小的点即可 但是对二维降序排列为什么不信呢?? /* */ #include<iostream> #include<cstring ...
- P2152 [SDOI2009]SuperGCD 未完成
辗转相减求a,b的gcd其实可以优化的: 1.若a为偶数,b为奇数:gcd(a,b)=gcd(a/2,b) 2.若a为奇数,b为偶数:gcd(a,b)=gcd(a,b/2) 3.若a,b都是偶数:gc ...
- 解析Linux下\r\n的问题(回车和换行)
http://www.jb51.net/article/37389.htm 深入解析Linux下\r\n的问题 http://www.ruanyifeng.com/blog/2006/04/post_ ...
- python全栈开发day24-__new__、__del__、item系列、异常处理
一.昨日内容回顾 1.反射 用字符串类型的名字,操作命名空间的变量. 反射使用场景:明显的简化代码,能拿到的变量名本来就是一个字符串类型的时候, 用户输入的,文件读入的,网上传输的 2.__call_ ...
- Jquery empty() remove() detach() 方法的区别
方法简介: empty() This method removes not only child (and other descendant) elements, but also any text ...