喵哈哈村的秘境探险系列。

A.

实际上就是求乘积%k是否等于0,显然 a * b % k = (a%k)*(b%k)%k,所以边乘边取模就好了。

#include<bits/stdc++.h>
using namespace std; int main(){
long long n,k;
while(cin>>n>>k){
long long now = 1;
for(int i=0;i<n;i++){
long long x;
cin>>x;
now = now * x % k;
}
if(now == 0)
cout<<"Yes"<<endl;
else
cout<<"No"<<endl;
}
}

B.

异或是可以前缀和的,因为x^x=0,所以 答案就是sum[r]^sum[l-1]

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5+7;
int q,sum[maxn],n,a[maxn]; int main(){
//freopen("1.in","r",stdin);
//freopen("1.out","w",stdout);
while(cin>>n){
for(int i=1;i<=n;i++)
cin>>a[i];
for(int i=1;i<=n;i++)
sum[i]=a[i]^sum[i-1];
cin>>q;
while(q--){
int x,y;
cin>>x>>y;
cout<<(sum[y]^sum[x-1])<<endl;
}
}
}

C

不修改,是滑雪的经典题,就是一个记忆化搜搜。

第一个修改操作是O(1),剩下的每次O(n2)修改,然后O(n2)跑DP就好。。

#include <bits/stdc++.h>
using namespace std;
const int dx[]={0,0,1,-1};
const int dy[]={1,-1,0,0};
int f[705][705],mark[705][705],m[705][705];
int n;
int S(int x,int y){
if(mark[x][y])return 0;
if(f[x][y])return f[x][y];
f[x][y]=1;
for(int i=0;i<4;++i){
int _x=x+dx[i],_y=y+dy[i];
if(_x>n||_y>n||_x<1||_y<1)continue;
if(m[_x][_y]>=m[x][y])continue;
f[x][y]=max(f[x][y],S(_x,_y)+1);
}
return f[x][y];
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j){
scanf("%d",&m[i][j]);
}
char opt[2];
int m2,q,w,e,r;
scanf("%d",&m2);
for(int i=1;i<=m2;++i){
scanf("%s",opt);
if(opt[0]=='C'){
scanf("%d%d%d",&q,&w,&e);
m[q][w]=e;
}
else if(opt[0]=='S'){
scanf("%d%d%d%d",&q,&w,&e,&r);
for(int i=q;i<=e;++i)
for(int j=w;j<=r;++j)
mark[i][j]=1;
}
else if(opt[0]=='B'){
scanf("%d%d%d%d",&q,&w,&e,&r);
for(int i=q;i<=e;++i)
for(int j=w;j<=r;++j)
mark[i][j]=0;
}
else {
int ans=0;
memset(f,0,sizeof(f));
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j){
ans=max(ans,S(i,j));
}
printf("%d\n",ans);
}
} return 0;
}

D

算法其实很简单,我们以二进制为10111001这个数为例

原数为:

10111001

如果我们不取第一个1,那么后面7位我们可以随意取:

0*******

如果我们取第一个,不取第二个,那么后面5位我们可以随意取:

100*****

以此类推……

这样一来,我们就不受原数n的限定了,对于*部分,我们只需用组合数算出放1个1,放2个1,放3个1……的种数(记得加上前面已经确定的数位)

这样以来,我们也就知道了每种1的个数对应数的总数,题中是为了求乘积,那么快速幂即可

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long LL;
const int L_N=65;
const LL MOD=10000007;
LL f[L_N][L_N][2],NUM;
int val[L_N],len; LL pow(int d,LL k){
if(k==0) return 1;
LL t=pow(d,k/2);
t=t*t%MOD;
if(k%2) t=t*d%MOD;
return t;
} int main(){
scanf("%lld",&NUM); while(NUM){
val[++len]=NUM&1;
NUM>>=1;
}
reverse(val+1,val+1+len); f[0][0][1]=1;
for(int i=1;i<=len;i++){
for(int j=0;j<=i;j++){
f[i][j][0]+=f[i-1][j][0];
if(val[i]) f[i][j][0]+=f[i-1][j][1];
if(!val[i]) f[i][j][1]+=f[i-1][j][1]; if(j){
f[i][j][0]+=f[i-1][j-1][0];
if(val[i]) f[i][j][1]+=f[i-1][j-1][1];
}
}
} LL ans=1;
for(int i=1;i<L_N;i++){
LL d=f[len][i][0]+f[len][i][1];
ans=(ans*pow(i,d))%MOD;
} printf("%lld\n",ans); return 0;
}

E

树状数组/线段树来维护每个数的和,便于快速查询sum

更新的话,就直接暴力更新即可,因为每个数最多更新log(n)次就会到达1或者0

然后我们用并查集维护一下,如果更新到了1,就指向下一个需要更新的值就好了,直接跳过该值。

#include <cstdio>
#include <cmath>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
LL a[100005],c[100005];
int f[100005],n,m,op,l,r,t;
int find(int x){return x==f[x]?x:f[x]=find(f[x]);}
int update(int x,LL num){while(x<=n)c[x]+=num,x+=(x&-x);}
LL sum(int x){LL s=0;while(x)s+=c[x],x-=(x&-x);return s;}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)f[i]=i,scanf("%lld",&a[i]),update(i,a[i]);
scanf("%d",&m); f[n+1]=n+1;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&op,&l,&r);
if(l>r)swap(l,r);
if(op==1)printf("%lld\n",(sum(r)-sum(l-1)));
else for(int j=l;j<=r;update(j,(t=(int)sqrt(a[j]))-a[j]),a[j]=t,
f[j]=(a[j]<=1)?j+1:j,j=(find(j)==j?j+1:f[j]));
}
return 0;
}

喵哈哈村的魔法考试 Round #17 题解的更多相关文章

  1. 喵哈哈村的魔法考试 Round #7 (Div.2) 题解

    喵哈哈村的魔法考试 Round #7 (Div.2) 注意!后四道题来自于周日的hihocoder offer收割赛第九场. 我建了个群:欢迎加入qscoj交流群,群号码:540667432 大概作为 ...

  2. 喵哈哈村的魔法考试 Round #2 (Div.2) 题解

    喵哈哈村的魔法考试 Round #2 (Div.2) 题解 A.喵哈哈村的战争 题解: 这道题就是for一遍,统计每个村子的战斗力的和,然后统计哪个村子的战斗力和大一点就好了. 唯一的坑点,就是这道题 ...

  3. 喵哈哈村的魔法考试 Round #1 (Div.2) 题解

    喵哈哈村的魔法考试 Round #1 (Div.2) 题解 特别感谢出题人,qscqesze. 也特别感谢测题人Xiper和CS_LYJ1997. 没有他们的付出,就不会有这场比赛. A 喵哈哈村的魔 ...

  4. 喵哈哈村的魔法考试 Round #1 (Div.2) 题解&源码(A.水+暴力,B.dp+栈)

    A.喵哈哈村的魔法石 发布时间: 2017年2月21日 20:05   最后更新: 2017年2月21日 20:06   时间限制: 1000ms   内存限制: 128M 描述 传说喵哈哈村有三种神 ...

  5. 喵哈哈村的魔法考试 Round #19 (Div.2) 题解

    题解: 喵哈哈村的魔力源泉(1) 题解:签到题. 代码: #include<bits/stdc++.h> using namespace std; int main(){ long lon ...

  6. 喵哈哈村的魔法考试 Round #1 (Div.2)

    比赛地址:http://qscoj.cn/contest/2/ 都是中文题,这里不在详述题意 A.喵哈哈村的魔法石 分析:暴力求解 #include<iostream> #include& ...

  7. 喵哈哈村的魔法考试 Round #1 (Div.2) ABCD

    官方题解: http://www.cnblogs.com/qscqesze/p/6418555.html#3623453 喵哈哈村的魔法石 描述 传说喵哈哈村有三种神奇的魔法石:第一种魔法石叫做人铁石 ...

  8. 喵哈哈村的魔法考试 Round #14 (Div.2) 题解

    喵哈哈村的四月半活动(一) 题解: 唯一的case,就是两边长度一样的时候,第三边只有一种情况. #include <iostream> #include <cstdio> # ...

  9. 喵哈哈村的魔法考试 Round #4 (Div.2) 题解

    有任何疑问,可以加我QQ:475517977进行讨论. A 喵哈哈村的嘟嘟熊魔法(1) 题解 这道题我们只要倒着来做就可以了,因为交换杯子是可逆的,我们倒着去模拟一遍就好了. 有个函数叫做swap(a ...

随机推荐

  1. eclipse自动编译

    自动编译:对java应用没有什么意义,对web应用来说,当修改了代码时,会自动帮你编译并发布到web容器中去,省的重启web容器了. build:编译,Eclipse的编译是基于时间戳的判断机制的.c ...

  2. tomcat jsp页面乱码解决

    浏览器接收服务器响应的中文参数: JSP页面中告诉浏览器使用什么编码: <%@ page language="java" contentType="text/htm ...

  3. 转载:configure生成的文件(1.5.3)《深入理解Nginx》(陶辉)

    原文:https://book.2cto.com/201304/19620.html 当configure执行成功时会生成objs目录,并在该目录下产生以下目录和文件:|---ngx_auto_hea ...

  4. STM32F412应用开发笔记之十:多组分气体分析仪设计验证

    本次将NUCLEO-F412ZG应用于我们的多组分气体分析仪的实现试验,从整体上测试实际项目的应用情况. 一.项目概述 多组分气体分析仪是我公司近期研发的三个主要产品之一.采用模块化设计,可增减配置, ...

  5. LeetCode(52):N皇后 II

    Hard! 题目描述: n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给定一个整数 n,返回 n 皇后不同的解决方 ...

  6. 【mysql】MySQLdb返回字典方法

    来源:http://blog.csdn.net/zgl_dm/article/details/8710371 默认mysqldb返回的是元组,这样对使用者不太友好,也不利于维护下面是解决方法 impo ...

  7. *****hibernate主键生成

    一.主键主键是关系数据库中的一个基本概念,它用来保证记录的唯一性主键都是没有业务含义的,所以开发 者不会.也不需要,显示地设置实体对象的主键值.但是对于数据库来说,主键是必须的 Hibernate内置 ...

  8. python 全栈开发,Day109(客户管理之动态"二级"菜单)

    昨日内容回顾 1. 权限有几张表? 2. 简述权限流程? 3. 为什么要把权限放入session? 4. 静态文件和模块文件 5. 相关技术点 - orm查询 - 去空 - 去重 - 中间件 - in ...

  9. textarea 标签换行及靠左

    上图可以实现文字文字靠左,换行直接回车就行,效果见下图

  10. maven创建父子关系的聚合项目

    我最近使用eclipse的mavean插件创建父子关系的聚合项目,如果创建子工程直接在父工程我相信大家都会创建,但是子工程在父工程中的其中一个文件夹里面,我们创建子工程是直接存在父工程下面的,当我们想 ...