博客
关于我
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/

你可能感兴趣的文章
npm start运行了什么
查看>>
npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
查看>>
npm 下载依赖慢的解决方案(亲测有效)
查看>>
npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
查看>>
npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
查看>>
npm—小记
查看>>
npm介绍以及常用命令
查看>>
NPM使用前设置和升级
查看>>
npm入门,这篇就够了
查看>>
npm切换到淘宝源
查看>>
npm切换源淘宝源的两种方法
查看>>
npm前端包管理工具简介---npm工作笔记001
查看>>
npm升级以及使用淘宝npm镜像
查看>>
npm发布包--所遇到的问题
查看>>
npm发布自己的组件UI包(详细步骤,图文并茂)
查看>>
npm和yarn清理缓存命令
查看>>
npm和yarn的使用对比
查看>>
npm如何清空缓存并重新打包?
查看>>
npm学习(十一)之package-lock.json
查看>>
npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
查看>>