博客
关于我
The Bits CodeForces - 1017B(组合数学,水)
阅读量:240 次
发布时间:2019-03-01

本文共 1385 字,大约阅读时间需要 4 分钟。

状态转换问题的代码解释

这段代码是用来解决一个典型的状态转换问题。程序通过统计输入字符串中每对字符的转移次数,计算了不同状态之间的转换次数。

代码分析

#include 
#include
#include
#include
using namespace std;typedef long long ll;const int maxn = 1e6 + 5;int main() { int n; cin >> n; string a, b; cin >> a >> b; ll num00 = 0, num01 = 0, num10 = 0, num11 = 0; for (int i = 0; i < n; ++i) { char c1 = a[i], c2 = b[i]; if (c1 == c2) { if (c1 == '0') num00++; else num11++; } else { if (c1 == '0' && c2 == '1') num01++; else if (c1 == '1' && c2 == '0') num10++; } } // 输出结果 // ...}

代码解释

1. 包含头文件

  • iostream:用于标准输入输出操作
  • string:字符串操作
  • algorithm:算法库
  • cctype:字符分类和常用字符函数

2. 定义

  • using namespace std;:导入标准库
  • typedef long long ll;:定义长长整数类型
  • const int maxn = 1e6 + 5;:定义常量,用于数组大小

3. 主函数

int main() {    int n;    cin >> n;    string a, b;    cin >> a >> b;    ll num00 = 0, num01 = 0, num10 = 0, num11 = 0;    for (int i = 0; i < n; ++i) {        char c1 = a[i], c2 = b[i];        if (c1 == c2) {            if (c1 == '0') num00++;            else num11++;        } else {            if (c1 == '0' && c2 == '1') num01++;            else if (c1 == '1' && c2 == '0') num10++;        }    }    // ...}

4. 主循环

  • 遍历每个字符对
  • 判断两个字符是否相同
    • 如果相同,根据字符值更新对应的计数器
  • 如果不同,根据具体转换关系更新计数器

5. 输出结果

  • 根据计数器值输出最终结果

这段代码通过遍历两个字符串,统计每对字符的转移次数,适用于解决状态转换类的问题。

转载地址:http://ifnt.baihongyu.com/

你可能感兴趣的文章
P1035 I need help
查看>>
P1073 最优贸易
查看>>
P1207 双重回文数
查看>>
p1229
查看>>
P1273 有线电视网(树形dp)
查看>>
spring编程常见错误二 (学习笔记)
查看>>
P1364 医院设置
查看>>
P1614 爱与愁的心痛
查看>>
spring缓存注解@Cacheable、@CacheEvict、@CachePut使用
查看>>
P1865 A % B Problem
查看>>
P1908 逆序对
查看>>
P2158 [SDOI2008]仪仗队
查看>>
P2161 [SHOI2009]Booking 会场预约
查看>>
P2260 [清华集训2012]模积和
查看>>
P3203 [HNOI2010]弹飞绵羊 —— 懒标记?分块?
查看>>
P3240 [HNOI2015]实验比较 树形DP
查看>>
P3383 素数筛
查看>>
P3455 [POI2007]ZAP-Queries
查看>>
P3950部落冲突
查看>>
P4 Tutorials Flowlet Switching
查看>>