C - いっしょ / Be Together

数据比较小,暴力就挺好的。O(n^2)可过的好题

#include <bits/stdc++.h>
using namespace std; const int MAXN = 110;
int nums[MAXN],n; int main()
{
scanf("%d",&n);
for(int i = 0; i < n; ++i)
scanf("%d",&nums[i]);
int res = 999999999,cost = 0;
for(int i = -100; i <= 100; ++i)
{
cost = 0;
for(int j = 0; j < n; ++j)
cost += (nums[j]-i)*(nums[j]-i);
res = min(res,cost);
}
printf("%d\n",res);
return 0;
}

####D - アンバランス / Unbalanced
也比较水。
思路:假设当前字符串长度为偶数,字符x占了一半,另一半是别的字符,用 * 代替,则字符相邻的方式有两种,x和 * 交错排列;或者x和 * 不交错排列,这种情况下至少有两个x挨着。在交错排列的情况下,若x占了一半以上的话,则必定至少有两个x是挨着的,有种抽屉原理的感觉。对于长度为奇数的情况,即len为奇数,则当x字符占了一半以上,x字符至少有len/2+1个,这种情况下,有两种排列的方式,即交错排列和不交错的排列,也就是至少有两个x是挨着的或者两个x隔着一个字符。

综上,一个字符串的子串如果是不平衡的,则必定有某种字符两个挨在一块或者中间隔着一个。扫一遍判断下即可。

#include <bits/stdc++.h>
using namespace std; const int MAXN = 1e5+10;
char str[MAXN];
int len; int main()
{
int s = -1, e = -1;
scanf("%s",str);
len = strlen(str);
for(int i = 0; i < len-1; ++i)
{
if(str[i] == str[i+1])
{
s = i+1;
e = i+2;
break;
}
if(i+2 < len && str[i] == str[i+2])
{
s = i+1;
e = i+3;
break;
}
}
printf("%d %d\n",s,e);
return 0;
}

####E - キャンディーとN人の子供 / Children and Candies
感觉D和E的难度差距太大了,感觉一下子突然难了好多,可能是我dp太水了。
参考:http://kmjp.hatenablog.jp/entry/2016/08/13/1030
https://arc059.contest.atcoder.jp/submissions/1550056

思路:dp[k][n]表示把n个糖果分给k个孩子所得到的x[i]^a[i]的乘积的加和,就是题目要求的那玩意,感觉还挺绕呢。dp[k-1][n-m]表示把n-m个糖果分给k-1个孩子得到的结果。也就是第k个孩子给了他m个糖果。先考虑A[i]==B[i]的情况,这时候dp[k][n] += dp[k-1][n-m] * (A[i]^m)。当A[i] != B[i]的时候,则dp[k][n] += dp[k-1][n-m] * (A[i]^m + (A[i]+1)^m + ... + B[i]^m)。

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MAXN = 405;
const LL mod = 1e9+7;
LL sum[MAXN];
LL A[MAXN],B[MAXN];
LL dp[MAXN][MAXN];
LL N,C; LL calc(int a, int b)
{
memset(sum,0,sizeof(sum));
for(int i = a; i <= b; ++i)
{
LL t = 1;
for(int j = 0; j <= C; ++j)
{
sum[j] = sum[j]+t;
sum[j] %= mod;
t = t*i%mod;
}
}
} int main()
{
cin >> N >> C;
for(int i = 1; i <= N; ++i)
cin >> A[i];
for(int i = 1; i <= N; ++i)
cin >> B[i];
dp[0][0] = 1;
for(int i = 1; i <= N; ++i)
{
calc(A[i],B[i]);//计算A[i]^m + (A[i]+1)^m + ... + B[i]^m
for(int j = 0; j <= C; ++j)
for(int k = 0; k <= j; ++k)
dp[i][j] = (dp[i][j] + dp[i-1][j-k]*sum[k])%mod;
}
cout << dp[N][C] << endl;
return 0;
}

####F - バイナリハック / Unhappy Hacking
不会,E都吃力,F就不看了,题刷多了,回头再来一块搞F

AtCoder Regular Contest 059的更多相关文章

  1. AtCoder Regular Contest 059 F Unhappy Hacking

    Description 题面 Solution 我们发现如果一个位置需要被退掉,那么是 \(0\) 或 \(1\) 都没有关系 于是我们想到把 \(0,1\) 归为一类 问题转化为每一次可以添加和删除 ...

  2. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  3. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  4. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  5. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  6. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  7. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  8. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

  9. AtCoder Regular Contest 096

    AtCoder Regular Contest 096 C - Many Medians 题意: 有A,B两种匹萨和三种购买方案,买一个A,买一个B,买半个A和半个B,花费分别为a,b,c. 求买X个 ...

随机推荐

  1. javax.el.PropertyNotFoundException: Property 'studentAge' not found on type com.hs.model.StudentModel

    mi明明已经把这个字段重构了,为啥还这样提示呢?整个工程全部 查找也找不到这个字段了啊

  2. java list转换json格式

    /** * 处理返回值(转换json格式和补零) * * @param resultDto5List * @param dateList * @return */ private JSONObject ...

  3. 为什么打不开IDEA或webStorm官方网页?

    为什么打不开IDEA或webStorm官方网页? 一.问题描述 idea和webStorm的官网:https://www.jetbrains.com/ 有时候打开idea的官网会出现无法访问的情况,页 ...

  4. Zookeeper安装过程

    zookeeper的安装我反反复复安装了三次,前两次在root用户下安装都失败了,都启动不起来,第三次我改成普通用户安装,没想到成功了,很不可思议,步骤完全一样,接下来介绍一下具体的安装步骤: 1. ...

  5. 利用Git搭建自动部署的Laravel环境 - 钟晨宇的博客 - CSDN博客

    目标:服务器上搭建Laravel环境,本地使用IDE进行开发,使用Homestead做本地调试环境,代码提交后自动部署到服务器Root目录下. 下面是整个流程的示意图:  1. 准备工作,搭建LNMP ...

  6. activity与fragment之间的传递数据

    首先activity之间的数据传递就是 用intent和intent+bundle intent 传递 Intent i= new Intent(MainActivity.this,TheAty.cl ...

  7. 第一次接触node.JS

    1.初识node.js node.js平时可以关注: 一.nodejs.org看看nodejs的版本升级,新特性的加入,重要bug的修复等 二.www.npmjs.com模块社区,看他人源代码,省力 ...

  8. vi中如何跳转到指定行数

    输入:n,代表跳转到第n行,如:100,就跳转到第100行.

  9. 从0开始学习 GitHub 系列之「05.Git 进阶」

    关于 Git 相信大家看了之前一系列的文章已经初步会使用了, 但是关于Git还有很多知识与技巧是你不知道的,今天就来给大家介绍下一些 Git 进阶的知识. 1. 用户名和邮箱 我们知道我们进行的每一次 ...

  10. jQuery 图片上传

    1. 概述 1.1 说明 在一些前后端不分离的项目中,经常有一些需要把文件或者图片上传的功能,故记录此代码以便后期使用. 1.2 要求 1.上传,10M以内,限bmp,jpg,png,jpeg等图片格 ...