hdu 5583 Kingdom of Black and White(模拟,技巧)
- In the Kingdom of Black and White (KBW), there are two kinds of frogs: black frog and white frog.
- Now N frogs are standing in a line, some of them are black, the others are white. The total strength of those frogs are calculated by dividing the line into minimum parts, each part should still be continuous, and can only contain one kind of frog. Then the strength is the sum of the squared length for each part.
- However, an old, evil witch comes, and tells the frogs that she will change the color of at most one frog and thus the strength of those frogs might change.
- The frogs wonder the maximum possible strength after the witch finishes her job.
- First line contains an integer T, which indicates the number of test cases.
- Every test case only contains a string with length N, including only (representing
- a black frog) and (representing a white frog).
- ⋅ ≤T≤.
- ⋅ for % data, ≤N≤.
- ⋅ for % data, ≤N≤.
- ⋅ the string only contains and .
- For every test case, you should output "Case #x: y",where x indicates the case number and counts from and y is the answer.
- Case #:
- Case #:
- #pragma comment(linker, "/STACK:1024000000,1024000000")
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<cmath>
- #include<math.h>
- #include<algorithm>
- #include<queue>
- #include<set>
- #include<bitset>
- #include<map>
- #include<vector>
- #include<stdlib.h>
- #include <stack>
- using namespace std;
- #define PI acos(-1.0)
- #define max(a,b) (a) > (b) ? (a) : (b)
- #define min(a,b) (a) < (b) ? (a) : (b)
- #define ll long long
- #define eps 1e-10
- #define MOD 1000000007
- #define N 100006
- #define inf 1e12
- struct Node{
- char c;
- ll len;
- }node[N];
- char s[N];
- int main()
- {
- int t;
- ll ac=;
- scanf("%I64d",&t);
- while(t--){
- for(ll i=;i<N;i++){
- node[i].len=;
- }
- scanf("%s",s);
- ll len=strlen(s);
- ll k=;
- node[k].c=s[];
- node[k].len++;
- ll now=;
- for(ll i=;i<len;i++){
- if(s[i]==s[now]){
- node[k].len++;
- now++;
- }else{
- k++;
- node[k].c=s[i];
- node[k].len++;
- now++;
- }
- }
- //for(ll i=0;i<=k;i++){
- // prllf("%c %d\n",node[i].c,node[i].len);
- //}
- ll ans=;
- for(ll i=;i<=k;i++){
- ans+=node[i].len*node[i].len;
- }
- ll sum=ans;
- //prllf("%d\n",ans);
- for(ll i=;i<=k;i++){
- if(node[i].len==){
- if(i==){
- ll new_num=;
- ll old_num=;
- new_num=(node[].len+)*(node[].len+);
- old_num=(node[].len)*(node[].len)+(node[].len)*(node[].len);
- ans=max(ans,sum-old_num+new_num);
- }else if(i==k){
- ll new_num=;
- ll old_num=;
- new_num=(node[i-].len+)*(node[i-].len+);
- old_num=(node[i].len)*(node[i].len)+(node[i-].len)*(node[i-].len);
- ans=max(ans,sum-old_num+new_num);
- }else{
- ll new_num=;
- ll old_num=;
- new_num=(node[i-].len+)*(node[i-].len+);
- old_num=(node[i].len)*(node[i].len)+(node[i-].len)*(node[i-].len);
- ans=max(ans,sum-old_num+new_num);
- new_num=;
- old_num=;
- new_num=(node[i+].len+)*(node[i+].len+);
- old_num=(node[i].len)*(node[i].len)+(node[i+].len)*(node[i+].len);
- ans=max(ans,sum-old_num+new_num);
- new_num=;
- old_num=;
- if((node[i].c!=node[i-].c) && (node[i].c!=node[i+].c)){
- new_num=(node[i-].len++node[i+].len)*(node[i-].len++node[i+].len);
- old_num=(node[i].len)*(node[i].len)+(node[i+].len)*(node[i+].len)+(node[i-].len)*(node[i-].len);
- ans=max(ans,sum-old_num+new_num);
- }
- }
- }else{
- if(i==){
- ll new_num=;
- ll old_num=;
- new_num+=(node[].len-)*(node[].len-);
- new_num+=(node[].len+)*(node[].len+);
- old_num+=(node[].len)*(node[].len);
- old_num+=(node[].len)*(node[].len);
- ans=max(ans,sum-old_num+new_num);
- }else if(i==k){
- ll new_num=;
- ll old_num=;
- new_num+=(node[k].len-)*(node[k].len-);
- new_num+=(node[k-].len+)*(node[k-].len+);
- old_num+=(node[k].len)*(node[k].len);
- old_num+=(node[k-].len)*(node[k-].len);
- ans=max(ans,sum-old_num+new_num);
- }else{
- ll new_num=;
- ll old_num=;
- new_num+=(node[i-].len+)*(node[i-].len+);
- new_num+=(node[i].len-)*(node[i].len-);
- old_num+=(node[i].len)*(node[i].len);
- old_num+=(node[i-].len)*(node[i-].len);
- ans=max(ans,sum-old_num+new_num);
- new_num=;
- old_num=;
- new_num+=(node[i].len-)*(node[i].len-);
- new_num+=(node[i+].len+)*(node[i+].len+);
- old_num+=(node[i].len)*(node[i].len);
- old_num+=(node[i+].len)*(node[i+].len);
- ans=max(ans,sum-old_num+new_num);
- }
- }
- }
- printf("Case #%I64d: ",++ac);
- printf("%I64d\n",ans);
- }
- return ;
- }
hdu 5583 Kingdom of Black and White(模拟,技巧)的更多相关文章
- HDU 5583 Kingdom of Black and White 水题
Kingdom of Black and White Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showpr ...
- hdu 5583 Kingdom of Black and White
Kingdom of Black and White Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Ja ...
- HDU 5583 Kingdom of Black and White(暴力)
http://acm.hdu.edu.cn/showproblem.php?pid=5583 题意: 给出一个01串,现在对这串进行分组,连续相同的就分为一组,如果该组内有x个数,那么就对答案贡献x* ...
- hdu-5583 Kingdom of Black and White(数学,贪心,暴力)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5583 Kingdom of Black and White Time Limit: 2000/1000 ...
- HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力)
HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力) 题目链接http://acm.hdu.edu.cn/showproblem.php?pid=59 ...
- hdu 4948 Kingdom(推论)
hdu 4948 Kingdom(推论) 传送门 题意: 题目问从一个城市u到一个新的城市v的必要条件是存在 以下两种路径之一 u --> v u --> w -->v 询问任意一种 ...
- HDU5583 Kingdom of Black and White
Kingdom of Black and White Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Ja ...
- hdu 2629 Identity Card (字符串解析模拟题)
这题是一个字符串模拟水题,给12级学弟学妹们找找自信的,嘿嘿; 题目意思就是要你讲身份证的上的省份和生日解析出来输出就可以了: http://acm.hdu.edu.cn/showproblem.ph ...
- [HDOJ5583]Kingdom of Black and White(暴力)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5583 一个01串,求修改一个位置,使得所有数均为0或1的子串长度的平方和最大.先分块,然后统计好原来的 ...
随机推荐
- Qt4.7文档翻译:Qt样式单参考,Qt Style Sheets Reference(超长,超全)
内容目录 Qt样式单参考 可进行样式设置的部件列表 属性列表 图标列表 属性类型列表 伪状态列表 子控件列表 Qt样式单参考 Qt样式单支持各种属性.伪状态和子控件,这样使得妳能够自行设计部件的外观. ...
- SQL Server中各个系统表的作用
sysaltfiles 主数据库 保存数据库的文件 syscharsets 主数据库 字符集与排序顺序 s ...
- Checkbutton 和 Radiobutton
The Checkbutton widget is used to display a number of options to a user as toggle buttons. The user ...
- (一)boost库之日期、时间
(一)boost库之日期.时间 一.计时器 计时器,通常在一个项目中统计一个函数的执行时间是非常实用的. #include <boost/timer.hpp> void PrintU ...
- 关于SubclassWindow()和SubclassDlgItem
msdn上的解析 CWnd::SubclassWindowBOOL SubclassWindow( HWND hWnd ); Return Value Nonzero if the function ...
- cf466B Wonder Room
B. Wonder Room time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- TCP的那些事(转载)
(转载本站文章请注明作者和出处 酷 壳 – CoolShell.cn ,请勿用于任何商业用途) TCP是一个巨复杂的协议,因为他要解决很多问题,而这些问题又带出了很多子问题和阴暗面.所以学习TCP本身 ...
- Android 绘图工具库AChartEngine
From: http://www.oschina.net/p/achartengine AChartEngine是为android应用而设计的绘图工具库.目前该库的最新稳定版本是0.7,支持绘制以下类 ...
- 将常见对象转换成json字符串
public class JsonUtil { public static String objectTojson(Object obj) { StringBuilder json = new Str ...
- ORA-03113 通信通道的文件结尾(ORA-19804 ORA-16038-归档空间满的处理方法)
1.数据库启动报错SQL> startupORACLE 例程已经启动. Total System Global Area 1887350784 bytesFixed Size 2176848 b ...