http://acm.timus.ru/problem.aspx?space=1&num=1830

这道题需要理解题目操作的意思,

要更改第i位的状态,第i-1位必须激活为1,0-i-2位必须为0,如果0-i-1位开始时全为0,那么从0位开始进行操作

一.首先考虑对于0-i-1位都是0,需要更改i位的情况,需要 1.更改i-1位,2.按一下打开下一页

对于更改i-1位,需要1.更改i-2位,2.按一下打开下一页,3.更改i-2位

可以得到一个式子,设f[i]为第0-i-1位均为0时,使得状态成为第i位被更改,第0-i-1位仍为0的操作数,则f[i]=2*f[i-1]+1

二.因为从前往后更改会影响之前的状态,所以我们从后往前更改,当最后一个不相同位置e已被上面的操作更改后,只有e-1位为1,其它都为0,满足上面的条件,可以直接相加

三.对于更改最后一位e的操作,因为这个时候前面不一定全都为0,所以有:

假设第e位是第i个1,

对于第i-1个1,这个1是有用的,可以作为起点,如果它是第j位,它的操作数为f[j]+1,对于e来说,因为计算f[e]时认为2*f[j]+1,所以要减去f[j],

对于第i-2个1,这个1阻碍了第i-1个1,是无用的,如果它是第j位,它的操作数为3*f[j]+1(一次关闭操作),对于e来说,需要加上f[j]

对于第i-3个1,有用,

对于第i-4个1,无用........

依次类推,直接相加可得答案

四:注意long long

#include <cstdio>
#include <cstring>
using namespace std;
typedef long long ll;
char org[100],aim[100];
ll f[50];
int main(){
int n;
ll ans=0;
scanf("%d%s%s",&n,org,aim); f[0]=1;
for(int i=1;i<n;i++){
f[i]=2*f[i-1]+1;
} for(int i=n-1;i>=0;i--){
if(org[i]==aim[i])continue;
ll sub=0;
int fl=1;
for(int j=i-1;j>=0;j--){
if(org[j]=='1'){
sub=sub+f[j]*fl;
if(j!=i-1)org[j]='0';
fl=-fl;
}
}
if(i>0)org[i-1]='1';
ans+=(i>0?f[i-1]:0)-sub+1;
org[i]=aim[i];
} printf("%I64d\n",ans);
return 0;
}

  

URAL 1830 Help in the RNOS 思路,读题 难度:1的更多相关文章

  1. poj 2739 Sum of Consecutive Prime Numbers 素数 读题 难度:0

    Sum of Consecutive Prime Numbers Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19697 ...

  2. LeetCode 2 Add Two Numbers 模拟,读题 难度:0

    https://leetcode.com/problems/add-two-numbers/ You are given two linked lists representing two non-n ...

  3. ZOJ 3652 Maze 模拟,bfs,读题 难度:2

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4842 要注意题目中两点: 1.在踏入妖怪控制的区域那一刹那,先减行动力,然后才 ...

  4. 杭电ACM2076--夹角有多大(题目已修改,注意读题)

    杭电ACM2076--夹角有多大(题目已修改,注意读题) http://acm.hdu.edu.cn/showproblem.php?pid=2076 思路很简单.直接贴代码.过程分析有点耗时间. / ...

  5. hdu 3268 09 宁波 现场 I - Columbus’s bargain 读题 最短路 难度:1

    Description On the evening of 3 August 1492, Christopher Columbus departed from Palos de la Frontera ...

  6. 【托业】【全真题库】TEST01-03-阅读题

    [托业][全真题库]TEST01-03-阅读题

  7. HDUOJ--2079选课时间(题目已修改,注意读题)

    选课时间(题目已修改,注意读题) Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  8. Codeforces 61B【怪在读题】

    搞不懂为什么DFS的写法崩了,然后乱暴力,因为题意不是很懂... 主要还是读题吧(很烦 #include <bits/stdc++.h> using namespace std; type ...

  9. Codeforces 659B Qualifying Contest【模拟,读题】

    写这道题题解的目的就是纪念一下半个小时才读懂题...英文一多读一读就溜号... 读题时还时要静下心来... 题目链接: http://codeforces.com/contest/659/proble ...

随机推荐

  1. TabLayout与ViewPager同步后Tab的标题不显示

    一.概述 1.1 问题描述 TabLayout+ViewPager后,TabLayout的TabItem不显示的问题: 1.2 截图 二.结论 mTabs.setupWithViewPager(mVi ...

  2. motan rpc

    git :  帮助 文档 基本介绍 Motan是一套基于java开发的RPC框架,除了常规的点对点调用外,Motan还提供服务治理功能,包括服务节点的自动发现.摘除.高可用和负载均衡等.Motan具有 ...

  3. Oracle中的substr()函数详解案例

    1)substr函数格式   (俗称:字符截取函数) 格式1: substr(string string, int a, int b); 格式2:substr(string string, int a ...

  4. iis原理介绍

    它是一个程序,负责对网站的内容进行管理,以及对客户的请求(就是Http请求)做出反应.当用户对一个页面提出请求时,IIS做如下反应(忽略权限):1.把对方请求的虚拟路径转换成物理路径2.根据物理路径搜 ...

  5. Swoole学习(二)Swoole之TCP服务器的创建

    环境:Centos6.4,PHP环境:PHP7 <?php //创建TCP服务器 /** * $host 是swoole需要监听的ip,如果要监听本地,不对外服务,那么就是127.0.0.1;如 ...

  6. Session管理之超时设置和强制下线

    关于Session,在Java Web开发中,为我们提供了很多方便,Session是由浏览器和服务器之间维护的.好吧,闲话不多说,下面让我们一步一步来实现它们. (一)首先来说下Session超时时间 ...

  7. mongodb入门很简单(2)

    mongodb的安装 1.下载mongodb: www.mongodb.org  下载最新的stable版:我下载的版本是3.2.5 2.解压文件 3.不用编译:本身就是编译后的二进制可执行文件 打开 ...

  8. 如果css足够强大了,你还会用编程的方式实现去实现css已有的功能吗?

    现在css3 都出来的,但是其实我由于一些原因,有些css2中都能支持的样式,我都没有使用过.我感觉我真的有必要静下心来,去看看那些东西,看看哪些以前都被忽视掉的. 今天我主要来讲三个对于我们编程经常 ...

  9. MySQL INSERT语句

    insert的语法 INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [(col_name,...)] ...

  10. 【Discriminative Localization】Learning Deep Features for Discriminative Localization 论文解析(转)

    文章翻译: 翻译 以下文章来源: 链接