CF 803D Magazine Ad 题解
2019-08-16 07:56:24来源:博客园 阅读 ()
CF 803D Magazine Ad 题解
题面
正解:一道二分大水题!
A:为什么我得不到满分?
B : 评测的系统不一样啊!
A : 蛤?
正常情况下我们日常练习均使用的是windows系统,在windows下,string 本身是可以存储'\0'字符,'\0'字符只是char 数组的结束符。如果是一个字符一个字符赋值,string 是可以直接输出空字符的。
而在linux的情况下(比如OI或一些oj),string 和char[]是一个德行,根本就存不了’\0',此字符也作为string 的结束符。
所以说:在Linux下,读取换行一定要用两遍getchar(),否则:(本来应该)------->(结果)(前提是linux评测的)
#include <bits/stdc++.h> #pragma GCC optimize(2) using namespace std; int k,len; char s[2000010]; int ans; int bo[1000010]; int nxt[1000010]; int check(int x) { if(x==1) return 1; register int u=1+x; register int num=0; memset(bo,0,sizeof(bo)); while(u<=len){ register int tmp=nxt[u]; while(bo[tmp]&&tmp!=0){ tmp=nxt[tmp]; } if(tmp==0){ return 0; } else{ bo[tmp]=1; ++num; u=tmp+1 ; if(num>k) return 0; } u+=x; } return 1; } void erfen(int l,int r) { while(l!=r) { int midd=(l+r)>>1; if(check(midd)) r=midd; else l=midd+1; } ans=l; } int main () { cin>>k; k--; getchar(); //getchar(); //如果用linux评测就把该注释删掉 ,保留两个getchar() int num=0; while(1) { char ch=getchar(); if(ch=='\n') break; s[++num]=ch; } len=strlen(s+1); int pre=0; for(register int i=1;i<=len;i++){ if(s[i]==' ') s[i]='-'; nxt[i]=pre; if(s[i]=='-'){ pre=i; } } erfen(1,len); printf("%d",ans); }
原文链接:https://www.cnblogs.com/kamimxr/p/11278651.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:DP_Sumsets
- Unsolved --> Solved OJ思路题解 2020-05-30
- 【题解】Luogu1739 表达式括号匹配 2020-04-07
- 【题解】Building Strings Gym - 102152E 2020-03-31
- GPLT-天梯赛-题解目录 2020-03-22
- 题解 P5116 【[USACO18DEC]Mixing Milk】 2020-03-14
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash