很好奇这周为什么只有Beginner Contest而没有Regular Contest,本来想着去30minAK的,结果1个小时了还有一道题调不出来o(╯□╰)o

A:Parking

让我体验了下开场30sAC的快感......

#include <bits/stdc++.h>

using namespace std;

int main()
{
long long n,a,b;cin >> n >> a >> b;
if(n*a<b) cout << n*a;
else cout << b;
return ;
}

B:Harshad Number

#include <bits/stdc++.h>

using namespace std;

int main()
{
int n;cin >> n;
int temp=n,sum=;
while(temp) sum+=(temp%),temp/=;
if(n%sum==) cout << "Yes";
else cout << "No";
return ;
}

C:Shopping Street

很简单的暴力+位运算,然而直到最后也没调出来......

出来一看题解,发现只有一个地方不同:标程初始化-1<<30,我的初始化-1<<27

猛然发现1<<27到不了1e9,平时为了保险防溢出用1<<27没事,但最值为1e9时初始值要为1<<30或1e9+7

#include <bits/stdc++.h>

using namespace std;
int n;
bool open[][];
long long p[][]; long long cal(int x)
{
long long ret=;
for(int i=;i<=n;i++)
{
int sum=;
for(int j=;j<=;j++)
if(open[i][j] && (x&(<<j))) sum++;
ret+=p[i][sum];
}
return ret;
} int main()
{
cin >> n;
for(int i=;i<=n;i++)
for(int j=;j<=;j++)
cin >> open[i][j];
for(int i=;i<=n;i++)
for(int j=;j<=;j++)
cin >> p[i][j]; long long res=-(<<);
for(int i=;i<=;i++)
{
long long temp=cal(i);
res=max(res,temp);
}
cout << res;
return ;
}

D:Recording

题意:在m个频道中有n个节目需要录制,如第i个节目在start time i~end time i(not included)播放,则在start time i-0.5~end time i(not included)这个时间段中同一台录制机不能在其他频道中进行录制,问至少要多少个录制机?

思路很明显,判断哪个时间点上同时出现的节目最多即可

当时连频道这个数据都没管,直接树状数组对所有时间维护一下,最后选择和最大的时间点即可,结果WA了5发

这道题中有一个题意理解很重要,题中说 [s-0.5,e) 是不能在其他频道中录制。我当时把所有节目都按[s,e]处理了,但事实上题目中暗示如果两个节目属于同一频道,可以连续录制,就没有-0.5这个制约了......(比赛中其实发了clarification,但日文怎么看╮(╯▽╰)╭)

此题除了读题不够细致之外,一开始我有一个很大的问题就是没把频道m这个条件放在心上

在很多时候数据本身及其范围就可以带来很多提示,并从而想到更简便的做法

如果这题使用树状数组,为了对在同一频道中首尾相连的节目特殊处理还需要进行排序,原本的效率优势就没有了

而如果很好的使用了m<30这个条件,可以一个频道一个频道地处理,用差分前缀和优化即可,思路明显清晰

PS:这题中有一个-0.5的操作,本题可以直接在整数上处理,但在其他情况中遇到-0.5时,可将整个数组放大2倍,由s-0.5 ---> 2*s-1

#include <bits/stdc++.h>

using namespace std;
const int MAXN=;
int n,m,st[MAXN],et[MAXN],c[MAXN],pre[MAXN],res[MAXN]; int main()
{
cin >> n >> m;
for(int i=;i<=n;i++) cin >>st[i] >>et[i] >>c[i];
for(int i=;i<=m;i++)
{
memset(pre,,sizeof(pre));
for(int j=;j<=n;j++) if(c[j]==i) pre[st[j]]++,pre[et[j]+]--;
for(int j=;j<MAXN;j++) pre[j]+=pre[j-]; //差分约束和操作
for(int j=;j<MAXN;j++) if(pre[j]>) res[j]++; //因为i,j属于一个频道,所以只能算一次
} int ans=;
for(int i=;i<MAXN;i++) ans=max(ans,res[i]);
cout << ans;
return ;
}

Review:

这次面对4道水题处理的不够好,注意点:

1.在最值很大时一定要特殊考虑不能盲目使用平时的初始化值

2.读题时要对目标对象的限制语好好揣膜摩

3.要利用好每一个数据和范围,尽量不忽略

4.在复杂度允许O(n)操作时,在处理区间和问题时可不用树状数组,而直接使用差分前缀和

[Atcoder 080] A~D Tutorial的更多相关文章

  1. [Atcoder Grand Contest 004] Tutorial

    Link: AGC004 传送门 A: …… #include <bits/stdc++.h> using namespace std; long long a,b,c; int main ...

  2. [Atcoder Regular Contest 060] Tutorial

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

  3. [Atcoder Regular Contest 061] Tutorial

    Link: ARC061 传送门 C: 暴力$dfs$就好了 #include <bits/stdc++.h> using namespace std; typedef long long ...

  4. [Atcoder Regular Contest 065] Tutorial

    Link: ARC065 传送门 C: 最好采取逆序贪心,否则要多考虑好几种情况 (从前往后贪心的话不能无脑选“dreamer”,"er"可能为"erase"/ ...

  5. [Atcoder Regular Contest 064] Tutorial

    Link: ARC064 传送门 C: 贪心+对边界的特殊处理 #include <bits/stdc++.h> using namespace std; typedef long lon ...

  6. [Atcoder Regular Contest 063] Tutorial

    Link: ARC063 传送门 C: 将每种颜色的连续出现称为一段,寻找总段数即可 #include <bits/stdc++.h> using namespace std; ,len; ...

  7. [Atcoder Grand Contest 003] Tutorial

    Link: AGC003 传送门 A: 判断如果一个方向有,其相反方向有没有即可 #include <bits/stdc++.h> using namespace std; ]; map& ...

  8. [Atcoder Regular Contest 062] Tutorial

    Link: ARC 062 传送门 C: 每次判断增加a/b哪个合法即可 并不用判断两个都合法时哪个更优,因为此时两者答案必定相同 #include <bits/stdc++.h> usi ...

  9. [Atcoder Grand Contest 002] Tutorial

    Link: AGC002 传送门 A: …… #include <bits/stdc++.h> using namespace std; int a,b; int main() { sca ...

随机推荐

  1. 【Luogu】P3930 SAC E#1 - 一道大水题 Knight

    [题目]洛谷10月月赛R1 提高组 [题意]给定n*n棋盘和<=16个棋子,给几个棋子种类和攻击范围,现我方只有一马,求能否吃王. [算法]状压+BFS [题解]16种棋子中,马不能吃马,直接处 ...

  2. javascript中的addEventListener与attchEvent

    1.addEventListener 该方法用于向指定元素添加事件句柄 浏览器的支持情况为chrome1.0.ie9+.fireFox1.0.opera7.0 该方法包含三个参数event, func ...

  3. python基础===单元测试unittest

    ''' 编写一个名为Employee 的类,其方法__init__()接受名.姓和年薪,并 将它们都存储在属性中.编写一个名为give_raise()的方法,它默认将年薪增加5000 美元,但也能够接 ...

  4. 2014ACM/ICPC亚洲区广州站题解

    这一场各种计算几何,统统没有做. HDU 5129 Yong Zheng's Death HDU 5136 Yue Fei's Battle

  5. UIResponder简介

    1.简介 在使用设备的时候我们大多时候是但手指触摸控件了进行的,比如点击密码按钮解锁,上下浏览网页等动作.你肯定也摇动过iphone抢红包和***等等,我们的系统可以处理这些事件则都需要去使用UIRe ...

  6. Leetcode 之Length of Last Word(38)

    做法很巧妙.分成左右两个对应的部分,遇到左半部分则入栈,遇到右半部分则判断对应的左半部分是否在栈顶.注意最后要判断堆栈是否为空. bool isValid(const string& s) { ...

  7. phpcms v9表单向导添加验证码

    要做留言板的功能,故用添加表单,想要在提交留言前加一个验证码的功能.网上的教程比较混乱,于是亲自实验了下,步骤如下: 首先是调用表单的页面加入验证码.表单js调用模版默认的是 \phpcms\temp ...

  8. LeetCode解题报告—— Reverse Nodes in k-Group && Sudoku Solver

    1. Reverse Nodes in k-Group Given a linked list, reverse the nodes of a linked list k at a time and ...

  9. Django 1.6在Windows平台下的配置

    Django 1.6 在Windows平台下的配置 前言 最近两天研究了下Django1.6在Windows平台中的配置安装,服务器采用Apache.期间遇到过许多新手所遇到的各种问题,也算是一种宝贵 ...

  10. AC日记——矩阵取数游戏 洛谷 P1005

    矩阵取数游戏 思路: dp+高精: 代码: #include <bits/stdc++.h> using namespace std; #define ll long long struc ...