喵哈哈村的魔法考试 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了,那么就会无限循环 ...
随机推荐
- C#实现Zip压缩解压实例
原文地址:https://www.cnblogs.com/GoCircle/p/6544678.html 本文只列举一个压缩帮助类,使用的是有要添加一个dll引用ICSharpCode.SharpZi ...
- Flutter学习笔记与整合
1.Dart 面向对象语言,与java类比学习 非常适合移动和Web应用程序 1.dart官网 2.Dark2 中文文档 3.Dart语法学习 4.极客学院Dart学习 5.Flutter与Dart ...
- LeetCode(1):两数之和
写在前面:基本全部参考大神“Grandyang”的博客,附上网址:http://www.cnblogs.com/grandyang/p/4130379.html 写在这里,是为了做笔记,同时加深理解, ...
- PHP中的一些常用函数
<?php //===============================时间日期=============================== //y返回年最后两位,Y年四位数,m月份数字 ...
- web中切图、快速切图与web雪碧图制作的方法
声明: web小白的笔记,欢迎大神指点,联系QQ:1522025433. 工具:Photoshop 1.复制文字:点击文章工具后选择文字. 2.矩形选框工具 看信息 f8, 取消矩形选框 Ctrl+D ...
- 微信公众号开发JS-SDK(1.2)
概述 微信js-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微 ...
- Spring整合Quartz实现动态定时器,相关api,定时器添加,删除,修改
一.版本说明 spring3.1以下的版本必须使用quartz1.x系列,3.1以上的版本才支持quartz 2.x,不然会出错. 原因:spring对于quartz的支持实现,org.springf ...
- jquery的clone方法应用于textarea和select的bug修复不能copy值,clone id重复的解决
textarea和select的值clone的时候会丢掉,在clone的时候将val再重新赋值一下,如果知道这个了就简单了, 测试发现,textarea和select的jquery的clone方法有问 ...
- 带信号灯的最短路dijkstra问题(阿里巴巴2018校园招聘算法题)
题目描述 现在城市有N个路口,每个路口有自己的编号,从0到N-1,每个路口还有自己的交通控制信号,例如0,3表示0号路口的交通信号每3个时刻变化一次,即0到3时刻0号路口允许通过,3到6时刻不允许通过 ...
- 【开源小软件 】Bing每日壁纸 让桌面壁纸保持更新
发布一个开源小软件,Bing每日壁纸. 该小软件可以自动获取Bing的精美图片设置为壁纸,并且支持随机切换历史壁纸,查看壁纸故事. 欢迎大家下载使用,点star!有问题请留言或者提issue. 开源地 ...