喵哈哈村的木星传说(一)

旋转90°,找找规律就知道(x,y)->(n-1-y,x)

然后输出就好了。

#include<bits/stdc++.h>
using namespace std; const int maxn = 55;
int n,mp[maxn][maxn];
int main(){
while(scanf("%d",&n)!=EOF){
for(int i=0;i<n;i++){
for(int j=0;j<n;j++)
cin>>mp[i][j];
}
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
if(j==0){
cout<<mp[n-1-j][i];
}else{
cout<<" "<<mp[n-1-j][i];
}
}
cout<<endl;
}
}
}

喵哈哈村的木星传说(二)

考虑每一个字符串,我们观察知道字符串的字母顺序实际上是没有关系的。

那么我们首先将字符串内的字符排序,然后再看看一共有多少种字符串就好了。

#include<bits/stdc++.h>
using namespace std; set<string> S;
int n;
int main(){
while(cin>>n){
S.clear();
for(int i=0;i<n;i++){
string s;
cin>>s;
sort(s.begin(),s.end());
S.insert(s);
}
cout<<S.size()<<endl;
}
}

喵哈哈村的木星传说(三)

考虑dp[i][j]表示左边选了i个,右边选了j个dp的最大值。

那么dp[i][j]就可以从dp[i-1][j],dp[i][j-1]转移过来。

然后输出最大的就好了。

#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
using namespace std;
int f[2005][2005];
int n,a[2005],ans=0;
int main()
{
while(scanf("%d",&n)!=EOF){
memset(f,0,sizeof(f));
ans = 0;
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
for(int i=0;i<=n;i++)
for(int j=0;j<=n-i;j++)
f[i+1][j+1]=max(f[i][j+1]+(i+j)*a[i],f[i+1][j]+(i+j)*a[n-j+1]);
for(int i=0;i<=n;i++)ans=max(ans,f[i+1][n-i+1]);
printf("%d\n",ans);
}
return 0;
}

喵哈哈村的木星传说(四)

首先行走的路线,贪心可以直到显然是(n>m)(0,0)->(1,0)->(2,0)->....->(n,0)->(n,1)->(n,2)->...->(n,m)这样走。

然后整理一下公式,发现答案 = n + C(n+m+1,m),然后C(n+m+1,m)这个用lucas做出来就好。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#define P 1000000007
#define ll long long
using namespace std;
inline ll read()
{
ll x=0;char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x;
}
ll n,m;
ll qpow(ll a,ll b)
{
ll ans=1;
for(ll i=b;i;i>>=1,a=(a*a)%P)
if(i&1)ans=ans*a%P;
return ans;
}
ll C(ll a,ll b)
{
if(b>a)return 0;
if(b>a-b)b=a-b;
ll s1=1,s2=1;
for(ll i=1;i<=b;i++)
{
s1=s1*(a-i+1)%P;
s2=s2*i%P;
}
return s1*qpow(s2,P-2)%P;
}
ll lucas(ll a,ll b)
{
return C(a/P,b/P)*C(a%P,b%P);
}
int main()
{
while(cin>>n>>m){
//n=read();m=read();
printf("%lld\n",(lucas(n+m+1,min(n,m))+max(n,m))%P);
}
return 0;
}

喵哈哈村的木星传说(五)

这是一道数学题。。。

我们来举个例子:有一条边R从x指向y,它的数值大于0,AB对弈,现在A走

{

那么如果数值为1,A走过去,数值变为0,B就走不回来了

  如果数值为2,A走过去,数值变为1,如果B走回来,A不就死了?我们认为他们都足够聪明(虽然没有最强大脑聪明),怎么会做这么逗比的事情呢?(假设过来的前一条边已经走完了,数值为0)

  如果数值大于3(我们假定为3),A走过去,数值变为2,B如果仁慈地走回来,数值变为1,这样不就浪费了一步?

                            B如果按照题意残忍地用最佳行动走回来,取光所有数值,那么数值变为0,这条路就封死了,A做了一件无意义的事情,还封死了自己可以走的一条路,这对于先手的A而言是不利的,

                            这两种方法都明显有违双方最优的前提。  

}

★★★所以我们可以知道,无论是A走还是B走,即无论是先手走还是后手走,每走过一条路都一定取完,这样问题就简单了★★★

因为至少有个0,所以就简单了一点。。谁把对手逼到死路(两边都是0的)就赢了

从起始点开始向两边找,只要有一边到0边距离为奇数就是先手赢反之后手赢

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<set>
#include<queue>
#include<map>
#define pa pair<int,int>
#define inf 1000000000
#define ll long long
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int n,l,r;
int a[50];
int main()
{
while(cin>>n)
{
l=0;
r=n;
for(int i=1;i<=n;i++)a[i]=read();
while(a[l+1])l++;
while(a[r])r--;
r=n-r;
if(l&1||r&1)puts("YES");
else puts("NO");
}
return 0;
}

喵哈哈村的魔法考试 Round #13 (Div.2) 题解的更多相关文章

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

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

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

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

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

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

  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 #14 (Div.2) 题解

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

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

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

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

    题解: A 喵哈哈村的跳棋比赛 题解:其实我们要理解题意就好了,画画图看看这个题意.x<y,那么就交换:x>y,那么x=x%y. 如果我们经过很多次,或者y<=0了,那么就会无限循环 ...

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

    喵哈哈村的古怪石碑(一) 题解:暴力check一下是等比数列还是等差数列,然后输出答案即可.注意如果数据范围是1e9的话,就要快速幂了. 代码: #include <cstdio> #in ...

随机推荐

  1. C/C++杂记:虚函数的实现的基本原理

    1. 概述 简单地说,每一个含有虚函数(无论是其本身的,还是继承而来的)的类都至少有一个与之对应的虚函数表,其中存放着该类所有的虚函数对应的函数指针.例: 其中: B的虚函数表中存放着B::foo和B ...

  2. 005_nginx414_nginx 414 Request-URI Too Large

    一.开发请求一个非常长的请求参数 https://jiaju.jyall.me/backend/dish/getSales/?dishId=167271&dishId=166975&d ...

  3. zabbix安装及简单配置

    Zabbix基本介绍: zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案.它能监视各种网络参数,保证服务器系统的安全运营:并提供柔软的通知机制以让系统管理员快 ...

  4. 电信运营商 IT 系统介绍

    业务支撑系统 BSS: Business support system  运营支撑系统 OSS: Operation support system  管理支撑系统 MSS: Management Su ...

  5. Ex 6_4 判断序列是否由合法单词组成..._第六次作业

    设字符串为s,字符串中字符的个数为n,vi[i]表示前i+1个字符是否能组成有效的单词vi[i]=true表示能组成有效的单词,vi[i]=false表示不能组成有效的单词,在每个字符串前加一个空格, ...

  6. PYTHON-组合 封装 多态 property装饰器

    # 组合'''软件重用的重要方式除了继承之外还有另外一种方式,即:组合组合指的是,在一个类中以另外一个类的对象作为数据属性,称为类的组合 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之 ...

  7. 最全的基于MFC的ActiveX控件开发教程

    浏览器插件之ActiveX开发(一) 一般的Web应用对于浏览器插件能不使用的建议尽量不使用,因为其涉及到安全问题以及影响用户安装(或自动下载注册安装)体验问题.在有特殊需求(如涉及数据安全的金融业务 ...

  8. Sandcastle方法生成c#.net帮助类帮助文档chm

    Sandcastle方法生成c#.net帮助类帮助文档即chm后缀的文档,其实是通过C#文档注释生成的XML文件来生成帮助文档的.因此,第一步就是生成XML文档, 步骤1生成XML文档 1.打开VS- ...

  9. Mac配置Java开发环境

    笔者从Window上转到Mac上做开发,一切配置都要重新开始,开发环境配置介绍如下: 1. 下载JDK 从下面链接选择合适版本的安装包进行下载...笔者下载的是jdk-9.0.1 链接:http:// ...

  10. OCM_第六天课程:Section3 —》数据库可用性

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...