【codeforces 803D】Magazine Ad
【题目链接】:http://codeforces.com/contest/803/problem/D
【题意】 
 
给你一个字符串; 
其中的空格和连字符表示可以折叠的部分 
(就是说能在那个位置把字符串分成两部分,且和两部分分到两行去); 
这个操作能够使得原字符串不断变小; 
问你最后获得的所有字符串(可能分裂成了多个,所以是”所有”)中最长的那个最短能够是多少; 
(这个操作最多只能操作k次)
【题解】 
 
二分答案; 
枚举最后那个最长的长度是多少x; 
现在,相当于让你最多切k-1刀; 
使得k个部分,每个部分的长度都小于等于x; 
问你可不可行; 
这个模拟可不可行的部分贪心就能写;(加上这一段之后如果还能小于等于x,就让它们在同一段,否则到另外一段(其实也就对应了在不同的行)); 
 
【Number Of WA】 
 
0 
 
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 1e6+100;
int k,nex[N],n;
char s[N];
bool ok(LL x)
{
    LL now = 0,tot = 0;
    for (int i = 1;i<=n; )
    {
        if (nex[i]-i+1>x) return false;
        if (now+nex[i]-i+1<=x)
        {
            now+=nex[i]-i+1;
            i = nex[i]+1;
        }
        else
        {
            now = 0,tot++;
        }
    }
    if (now) tot++;
    return tot<=k;
}
int main()
{
    //freopen("F:\\rush.txt","r",stdin);
//    ios::sync_with_stdio(false),cin.tie(0);//scanf,puts,printf not use
    cin >> k;char t = getchar();
    gets(s+1);
    n = strlen(s+1);
    int be = n;
    rep2(i,n,1)
    {
        if (isupper(s[i])||islower(s[i]))
            continue;
        nex[i+1] = be;
        be = i;
    }
    nex[1] = be;
    LL l = 1,r = n,ans;
    while (l<=r)
    {
        LL mid = (l+r)>>1;
        if (ok(mid))
        {
            ans = mid,r = mid-1;
        }
        else
            l = mid+1;
    }
    cout << ans << endl;
    return 0;
}【codeforces 803D】Magazine Ad的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
		[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ... 
- 【codeforces 787A】The Monster
		[题目链接]:http://codeforces.com/contest/787/problem/A [题意] 把b一直加a->得到x 把d一直加c->得到y 然后问你x和y可不可能有相同 ... 
- 【codeforces 707E】Garlands
		[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ... 
- 【codeforces 707C】Pythagorean Triples
		[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ... 
- 【codeforces 709D】Recover the String
		[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ... 
- 【codeforces 709B】Checkpoints
		[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ... 
- 【codeforces 709C】Letters Cyclic Shift
		[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ... 
- 【Codeforces 429D】 Tricky Function
		[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ... 
- 【Codeforces 670C】 Cinema
		[题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ... 
随机推荐
- HDU 1754  I Hate it  (线段树最大值模板)
			思路:与我发表的上一遍求和的思想一样 仅仅是如今变成求最大值而已 AC代码: #include<iostream> #include<cstdio> #include< ... 
- 关于jetty服务器默认首页和端口设置
			一.jetty服务器部署.启动成功后,在浏览器输入http://localhost:8080/ 可以直接访问到jetty欢迎首页. 这是因为在Jetty包中默认带了一个test.war的应用,在${J ... 
- Adding a model
			https://docs.asp.net/en/latest/tutorials/first-mvc-app/adding-model.html Adding data model classes I ... 
- iOS10 推送通知 UserNotifications
			简介 新框架 获取权限 获取用户设置 注册APNS,获取deviceToken 本地推送流程 远程推送流程 通知策略(Category+Action) 附件通知 代理回调 简介 iOS10新增了Use ... 
- php执行运算符
			php执行运算符 简介 php 支持一个执行运算符:反引号(``).反引号(``)位于键盘Tab键左上方.php 将尝试将反引号中的内容作为外壳命令来执行,并将其输出信息返回(例如,可以赋给一个变量而 ... 
- 46.Qt 使用OpenGL绘制立方体
			main.cpp #include <QApplication> #include <iostream> #include "vowelcube.h" in ... 
- poj 1161 Floyd+枚举
			题意是: 给出n个点,围成m个区域.从区域到另一个区域间需穿过至少一条边(若两区域相邻)——边连接着两点. 给出这么一幅图,并给出一些点,问从这些点到同一个区域的穿过边数最小值. 解题思路如下: 将区 ... 
- 什么是 HTML5?
			HTML5 是下一代的 HTML. 什么是 HTML5? HTML5 将成为 HTML.XHTML 以及 HTML DOM 的新标准. HTML 的上一个版本诞生于 1999 年.自从那以后,Web ... 
- 使用angular.js获取form表单中的信息
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- mybatis学习笔记之基础复习(3)
			mybatis学习笔记之基础复习(3) mybatis是什么? mybatis是一个持久层框架,mybatis是一个不完全的ORM框架.sql语句需要程序员自己编写, 但是mybatis也是有映射(输 ... 
