C - 高橋君とカード / Tak and Cards

思路:dp,先说说我想的,我写的dp数组是dp[i][j][k],表示从前i个数字中,选择j个数字,平均值为k,则dp[i][j][k] = dp[i-1][j][k]+dp[i-1][j-1][(j*k-nums[i])/(j-1)],即第i个选或者不选。不过错了。。。。标程给出的题解思路差不多,dp[i][j][k]表示前i个数字中选取j个数字,和为k。dp[i][j][k] = dp[i-1][j][k]+dp[i-1][j-1][k-nums[i]]。时间复杂度为O(n^4)

#include <bits/stdc++.h>
using namespace std; const int MAXN = 55;
long long dp[MAXN][MAXN][MAXN*MAXN];
int nums[MAXN];
int n,a; int main()
{
scanf("%d %d",&n,&a);
for(int i = 1; i <= n; ++i)
scanf("%d",&nums[i]);
dp[0][0][0] = 1;
for(int i = 1; i <= n; ++i)
{
for(int j = 0; j <= i; ++j)
{
for(int k = 0; k <= n*50; ++k)
{
if(k >= nums[i] && j > 0) dp[i][j][k] += (dp[i-1][j][k]+dp[i-1][j-1][k-nums[i]]);
else dp[i][j][k] += dp[i-1][j][k];
}
}
}
long long res = 0;
for(int i = 1; i <= n; ++i)
res += dp[n][i][i*a];
printf("%lld\n",res);
return 0;
}

#### D - 桁和 / Digit Sum
思路:感觉这题思路就很新了,主要是因为没见过这种题。看数据范围是1e11,sqrt(n)的时间复杂度还是很好的。标程是把b分了两种情况来求解,一种是bsqrt(n)。当bsqrt(n)的时候,n=pb+q,因为这时b^2>n。考虑n的b进制表示为x2x1x0。则n=x0 + x1 * b + x2 * b^2,因为b^2>n,所以x2=0,所以这时候n = pb+q,则s=p+q。联立两式,得到n-s=p * (b-1)(标程中这里p和b写混了),然后枚举n-s的因子即可。
```c++
#include
using namespace std;
typedef long long LL;
const LL INF = 1e13;
LL n,s,st,sum;

void dfs(LL num, LL base)

{

if(num == 0) return;

dfs(num/base,base);

sum += num%base;

}

int main()

{

cin >> n >> s;

if(s > n)

{

cout << -1 << endl;

return 0;

}

if(s == n)

{

cout << s+1 << endl;

return 0;

}

st = sqrt(n) + 1;
for(LL i = 2; i <= st; ++i)
{
sum = 0;
dfs(n,i);
if(sum == s)
{
cout << i << endl;
return 0;
}
}
LL b,q,res = INF;
n = n-s;
for(LL i = 1; i*i <= n; ++i)
{
if(n%i == 0)
{
b = n/i+1;
q = s-i;
if(q >= 0 && b >= 2 && q < b && i < b)
res = min(res,b);
}
}
cout << (res==INF?-1:res) << endl;
return 0;

}

<hr/>
#### E - 高橋君とホテル / Tak and Hotels
思路:首先呢,是想预处理每个点向右和向左最远能扩展的距离,想到这里,发现不会预处理,遂放弃。然后想以每个点为终点,计算出最左边起点到这个点的最短时间和最右边点到这个最短天数,发现这种情况下,不能保证a-b这一段中,a是作为起始点的,放弃。看题解。英文题解没看懂,把日文题解翻译成中文才看懂了。主要思路就是利用倍增的思想,处理出每个点向右或者向左在x天内最远能到达的距离。r[k][i]表示节点i在2^k天内最远能到达的点,r[k+1][i]=r[k][r[k][i]]。然后算天数就好了。
```c++
#include <bits/stdc++.h>
using namespace std; const int MAXN = 1e5+10;
int dp[30][MAXN],x[MAXN],l,n;
int q; int main()
{
int i,j;
cin >> n;
for(int i = 1; i <= n; ++i)
cin >> x[i];
cin >> l;
for(int i = 1; i < n; ++i)
dp[0][i] = upper_bound(x+1,x+n+1,x[i]+l) - x - 1;
for(i = 1; i < 30; ++i)
{
for(j = 1; j <= n; ++j)
dp[i][j] = dp[i-1][dp[i-1][j]];
}
cin >> q;
int a,b,res;
while(q--)
{
res = 0;
cin >> a >> b;
if(a > b) swap(a,b);
for(i = 29; i >= 0; --i)
{
if(dp[i][a] == 0) continue;
if(dp[i][a] < b)
{
a = dp[i][a];
res += (1<<i);
}
}
cout << res+1 << endl;
}
return 0;
}

#### F - 最良表現 / Best Representation
待补

AtCoder Regular Contest 060的更多相关文章

  1. [Atcoder Regular Contest 060] Tutorial

    Link: ARC060 传送门 C: 由于难以维护和更新平均数的值: $Average->Sum/Num$ 这样我们只要用$dp[i][j][sum]$维护前$i$个数中取$j$个,且和为$s ...

  2. Atcoder Regular Contest 060 F题第一问答案证明

    一切的开始 令 \(x\) 为字符串,\(p\) 为正整数.如果对于满足 \(0\le i<|x|−p\) 的任何整数 \(i\) 满足 \(x[i]=x[i+p]\),则 \(p\) 称为 \ ...

  3. AtCoder Regular Contest 061

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

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

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

  5. AtCoder Regular Contest 092

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

  6. AtCoder Regular Contest 093

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

  7. AtCoder Regular Contest 094

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

  8. AtCoder Regular Contest 095

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

  9. AtCoder Regular Contest 102

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

随机推荐

  1. 10.30NOIP集训总结

    1.第一眼是优先队列,然后发现n很大. 然后再观察一下,发现就可以二分,然后套用莫比乌斯反演里面的分块. 然后卡卡常就过了. 发现一个严肃的事情,就是说long long相除(相模)都会占用很多时间. ...

  2. [jnhs]教训之jsp页面无法用jstl取值的坑.真他妈的奇葩,实体类的属性名不能用大写

    结果页面永远都是空 调试发现,数据正常的塞进去了 问题解决: https://zhidao.baidu.com/question/570584436.html 实体类的属性名,首字母不能大写,改成小写 ...

  3. WAP网站的推广方式(自整合篇)

    WAP网站推广随着无线互联时代的到来,已经日益受到大家的重视.虽然WAP网站的目前盈利模式还不是很清晰,但WAP网站推广的竞争强度将肯定会越来越激烈,下面和大家一起探讨下WAP网站的推广方法. 方法/ ...

  4. 2019.8.1 NOIP模拟测试11 反思总结

    延迟了一天来补一个反思总结 急匆匆赶回来考试,我们这边大家的状态都稍微有一点差,不过最后的成绩总体来看好像还不错XD 其实这次拿分的大都是暴力[?],除了某些专注于某道题的人以及远程爆踩我们的某学车神 ...

  5. ubuntu安装verilog

    1.安装verilog sudo apt-get install verilog 2.安装gtkwave sudo apt-get install gtkwave 3.安装dinotrace(和gtk ...

  6. LintCode刷题笔记-- Maximal Square

    标签:动态规划 题目描述: Given a 2D binary matrix filled with 0's and 1's, find the largest square containing a ...

  7. 打印begin~end

    要求: 输入:begin和end 输出:依次打印出begin到end import java.util.Scanner; //递归打印begin —— end public class demo1 { ...

  8. P1127

    题目描述 如果单词X的末字母与单词Y的首字母相同,则X与Y可以相连成X.Y.(注意:X.Y之间是英文的句号“.”).例如,单词dog与单词gopher,则dog与gopher可以相连成dog.goph ...

  9. 移动端以及 PC浏览器页面分享到朋友圈等的功能实现

    我们经常可以在一些 app上看到分享到朋友圈.微信好友.qq好友等功能,例如 饿了么.美团等 app,下单之后就会弹出给好友发红包的 modal窗,这在 app上很常见,app的权限可以很大,甚至连启 ...

  10. git reset三种模式

    reset三种模式区别和使用场景 区别: --hard:重置位置的同时,直接将 working Tree工作目录. index 暂存区及 repository 都重置成目标Reset节点的內容,所以效 ...