CF:Problem 426B - Sereja and Mirroring 二分或者分治
这题解法怎么说呢,由于我是把行数逐步除以2暴力得到的答案,所以有点二分的意思,可是昨天琦神说是有点像分治的意思。反正总的来说:就是从大逐步细化找到最优答案。
可是昨晚傻B了。靠!
多写了点东西,然后就错了,刚才一练习,拿昨晚的代码一看,就把6行代码删去就过了。靠!昨晚应该是脑子进水了!!!!!
昨晚的代码:
- #include <iostream>
- #include <cstdio>
- #include <fstream>
- #include <algorithm>
- #include <cmath>
- #include <deque>
- #include <vector>
- #include <queue>
- #include <string>
- #include <cstring>
- #include <map>
- #include <stack>
- #include <set>
- #define PI acos(-1.0)
- #define mem(a,b) memset(a,b,sizeof(a))
- #define sca(a) scanf("%d",&a)
- #define sc(a,b) scanf("%d%d",&a,&b)
- #define pri(a) printf("%d\n",a)
- #define lson i<<1,l,mid
- #define rson i<<1|1,mid+1,r
- #define MM 4105
- #define MN 105
- #define INF 100004
- #define eps 1e-7
- using namespace std;
- typedef long long ll;
- int n,m,i,j,k,a[MN][MN];
- string s,ss;
- int main()
- {
- sc(n,m);
- for(i=0; i<n; i++)
- for(j=0; j<m; j++) sca(a[i][j]);
- if(n&1) cout<<n<<endl;
- else
- {
- int r=n/2,flag=1,ff=1;
- int aa=a[0][0];
- for(i=1; i<n; i++) //就是这个多推断了,由于自己给出的样列是1列。所以……靠。本来在以下的sum值那里已经处理了,然后忘了把这删了,所以就在第一列同样的时候出错了,导致昨晚没debug出来!嘛嘛呀。。!。
- if(aa!=a[i][0])
- {
- ff=0;
- break;
- }
- if(ff) cout<<1<<endl;
- else
- {
- int sum=0;
- while(r&&flag)
- {
- for(i=0; i<n&&flag; i+=r*2)
- {
- for(j=i,k=i+r+r-1; j<k&&flag; j++,k--)
- {
- for(int p=0; p<m&&flag; p++)
- if(a[j][p]!=a[k][p])
- flag=0;
- }
- }
- if(flag&&(r%2==0)) r/=2;
- if(flag&&(r&1)) sum++;
- if(sum>3) break;
- //cout<<"--"<<flag<<' '<<r<<endl;
- }
- if(!flag) cout<<r*2<<endl;
- else cout<<r<<endl;
- }
- }
- return 0;
- }
AC代码:
- #include <iostream>
- #include <cstdio>
- #include <fstream>
- #include <algorithm>
- #include <cmath>
- #include <deque>
- #include <vector>
- #include <queue>
- #include <string>
- #include <cstring>
- #include <map>
- #include <stack>
- #include <set>
- #define PI acos(-1.0)
- #define mem(a,b) memset(a,b,sizeof(a))
- #define sca(a) scanf("%d",&a)
- #define sc(a,b) scanf("%d%d",&a,&b)
- #define pri(a) printf("%d\n",a)
- #define lson i<<1,l,mid
- #define rson i<<1|1,mid+1,r
- #define MM 4105
- #define MN 105
- #define INF 100004
- #define eps 1e-7
- using namespace std;
- typedef long long ll;
- int n,m,i,j,k,a[MN][MN];
- string s,ss;
- int main()
- {
- sc(n,m);
- for(i=0; i<n; i++)
- for(j=0; j<m; j++) sca(a[i][j]);
- if(n&1) cout<<n<<endl;
- else
- {
- int r=n/2,flag=1,ff=1;
- int sum=0;
- while(r&&flag)
- {
- for(i=0; i<n&&flag; i+=r*2)
- {
- for(j=i,k=i+r+r-1; j<k&&flag; j++,k--)
- {
- for(int p=0; p<m&&flag; p++)
- if(a[j][p]!=a[k][p])
- flag=0;
- }
- }
- if(flag&&(r%2==0)) r/=2;
- if(flag&&(r&1)) sum++;
- if(sum>3) break;
- //cout<<"--"<<flag<<' '<<r<<endl;
- }
- if(!flag) cout<<r*2<<endl;
- else cout<<r<<endl;
- }
- return 0;
- }
CF:Problem 426B - Sereja and Mirroring 二分或者分治的更多相关文章
- Codeforces Round #243 (Div. 2) Problem B - Sereja and Mirroring 解读
http://codeforces.com/contest/426/problem/B 对称标题的意思大概是.应当指出的,当线数为奇数时,答案是线路本身的数 #include<iostream& ...
- B. Sereja and Mirroring
B. Sereja and Mirroring time limit per test 1 second memory limit per test 256 megabytes input stand ...
- Codeforces Round #424 (Div. 2, rated, based on VK Cup Finals) Problem D (Codeforces 831D) - 贪心 - 二分答案 - 动态规划
There are n people and k keys on a straight line. Every person wants to get to the office which is l ...
- fzu Problem - 2232 炉石传说(二分匹配)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2232 Description GG学长虽然并不打炉石传说,但是由于题面需要他便学会了打炉石传说.但是传统的炉石 ...
- CF 483B. Friends and Presents 数学 (二分) 难度:1
B. Friends and Presents time limit per test 1 second memory limit per test 256 megabytes input stand ...
- CF 314 E. Sereja and Squares
E. Sereja and Squares http://codeforces.com/contest/314/problem/E 题意: 给你一个擦去了部分左括号和全部右括号的括号序列,括号有25种 ...
- Problem: Query on the tree(二分+划分树)
题目链接: Problem: Query on the tree Time limit: 1s Mem limit: 64 MB Problem Description There ...
- CF 551E. GukiZ and GukiZiana [分块 二分]
GukiZ and GukiZiana 题意: 区间加 给出$y$查询$a_i=a_j=y$的$j-i$最大值 一开始以为和论文CC题一样...然后发现他带修改并且是给定了值 这样就更简单了.... ...
- CF 1073C Vasya and Robot(二分答案)
C. Vasya and Robot time limit per test 1 second memory limit per test 256 megabytes input standard i ...
随机推荐
- [置顶]
python3 django models保存filefiled字段统一目录、不修改文件名的方法
最经编写一个model时处理filefiled,使用post_form.save()进行新增和编辑文件保存位置不统一,如果出现重复文件名重复的话,上传文件名会被改名. 现有代码如下: models.p ...
- python获取输入参数
python获取输入参数 学习了:https://www.cnblogs.com/angelatian/p/5832448.html import sys模块: len(sys.argv)参数个数 s ...
- 创建es索引{"acknowledged"=>true, "shards_acknowledged"=>false}
创建es索引{"acknowledged"=>true, "shards_acknowledged"=>false} [2018-05-19T13: ...
- Windows 10 Enterprise LTSB版本
Windows 10 Enterprise 评估版 | 90 天 Win10 企业版 LTSB版 14393.0.160715-1616.RS1_RELEASE_CLIENTENTERPRISE ...
- Spring中如何配置事务
学过SSH的都知道,整合了SSH之后,SSH的经典增删改查案例业务逻辑层的代码就十分简单.基本上都是一句话的事. public void addUser(Webuserlogin user) { // ...
- iOS开发:Framework的创建
转载自:http://jonzzs.cn/2017/06/01/iOS%20开发笔记/[iOS%20开发]将自己的框架打包成%20Framework%20的方法/ 环境:Xcode 8 创建 Fram ...
- R 安装 简单实用
下载和安装Windows环境的R 1.进入主页,点击 蓝色加粗的 download R 2.随便点击一个镜像,这里点击的是http://mirror.fcaglp.unlp.edu.ar/CRAN/ ...
- charles用法详解
Charles是目前最强大的http调试工具,在界面和功能上远强于Fiddler,同时是全平台支持,堪称圣杯级工具,唯一的缺陷是这货是收费的,而且是要¥50美元大洋…当然网上是有破解版的,鄙视下自己, ...
- 程序员必备SQL语句优化技巧
1.任何地方都不要使用 select * from t ,用具体的字段列表代替"*",不要返回用不到的任何字段. 2.尽量使用数字型字段,字符型会降低查询和连接的性能,并会增加存储 ...
- PJISP 修改 消息头Fromto字段
项目需求,需要修改sip信令消息头中Fromto字段,完成此功能需要修改sip库(PJSIP)源码,具体如下: PJSIP 消息头 Formto 字段默认的格式是sip:平台@平台IP地址,例如si ...