【CSP】2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)完整代码+思路+遇到问题

本文主要是介绍【CSP】2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)完整代码+思路+遇到问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)

  • 2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)
    • 思路
    • 实现过程(遇到的问题)
    • 完整代码

2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)

做完一题回过来再看发现也不是做的时候觉得那么难,但是当时就是像傻子了一样,不会变通,想不到该怎么做。和碰到那个梯度下降的那道题一样,就蒙圈了找不到思路。以后碰到了模拟数学运算的题目,不是什么找数列找规律,就是简单的模拟手动计算,手动怎么计算,那么代码就怎么写。

然后看了别人的思路才会写,考试当然没有别人的思路可以看呢,那考试怎么办呢?

思路

这个题目分为两大部分,一部分是字符串处理,另一部分是模拟数学运算

  1. 字符串处理

字符串处理其实并不难,虽然不难自己写出来了,但是找bug还是花了很长时间的。

字符串处理主要就是按照题目给的,将输入的字符串处理加工,然后转换成对应的数字,没有什么难理解的。

  1. 模拟数学运算

模拟数学运算就是使用代码模拟这个的过程
在这里插入图片描述

就是遍历消除d(x)的k+1项到最后一项,那么最后k项的系数取反再取模就是所求的c

但是g(x)怎么求呢?肯定还是模拟手动啊。

循环遍历k次,每次乘以一个式子。

怎么乘呢?每个式子都有一个x和一个常数,乘以x就是左移一位,就是开头添加一个0,常数就是每个系数都乘以这个常数 就是这样。

实现过程(遇到的问题)

  1. 首先是对字符串处理中遇到的问题

    写判断语句出错

    原本的

        if (a >= '0 && a <= '9')to_state = 2;if (a <= 'Z' && a >= 'A')to_state = 3;if (a <= '0' && a >= '9')to_state = 1;
    

    改过的

        if (a >= '0' && a <= '9')to_state = 2;if (a <= 'Z' && a >= 'A')to_state = 3;if (a <= 'z' && a >= 'a')to_state = 1;
    

    写的时候没按顺序写果然会出错,然后debug 才看到的,应该先检查下代码有没有问题再去debug 的

  2. 初始状态没有搞清楚

    在这里插入图片描述

    没有注意到这句话,还以为是一开始是啥初始状态就是啥呢。

  3. 数据字段的开头有一个长度的数据

    这个数据我一开始没有主要到,还以为是输入的字符串的长度是多少就是多少呢,原来是在计算完转换成那个什么码后在看code_word有多长(包括他自己)

在这里插入图片描述

改完这3个bug就可以拿到40分了

在这里插入图片描述

  1. 接下来就是模拟多项式除法的过程了(计算校验码的过程)

看了别人的思路后,再写就没有再出错了,只是在取模的问题上有点问题

一开始只在结尾处取模

        for (int i = k - 1; i >= 0; i--){int temp = (-1 * d[i]) % 929;code_word.push_back(temp >= 0 ? temp : temp + 929);}

但是发现并不行只能拿到50分

在这里插入图片描述

然后我又在计算g(x) 计算d(x)的过程中取余

        for (int i = 2; i <= k; i++){vector<int> temp = g;g.insert(g.begin(), 0);for (int i = 0; i < temp.size(); i++){g[i] = (temp[i] * three) % 929 + g[i] % 929;g[i] % 929;}three = (three * 3);}
……
……for (int i = d.size() - 1; i >= k; i--){int temp = -1 * d[i];d[i] = 0;for (int j = g.size() - 2; j >= 0; j--){d[i - (g.size() - 1 - j)] = (g[j] * temp) % 929 + d[i - (g.size() - 1 - j)] % 929;d[i - (g.size() - 1 - j)] %= 929;}}

然后就拿到了80分

!在这里插入图片描述

之后再对three变量取模才100分

        for (int i = 2; i <= k; i++){vector<int> temp = g;g.insert(g.begin(), 0);for (int i = 0; i < temp.size(); i++){g[i] = (temp[i] * three) % 929 + g[i] % 929;g[i] % 929;}three = (three * 3) % 929;}

在这里插入图片描述

完整代码

#include <bits/stdc++.h>
using namespace std;
int s, w;
string init;
vector<int> numbers;
vector<int> code_word;
void convert_state(int &state, char a)
{int to_state = 0;if (a >= '0' && a <= '9')to_state = 2;if (a <= 'Z' && a >= 'A')to_state = 3;if (a <= 'z' && a >= 'a')to_state = 1;if (to_state == state) // 如果当前字母和当前状态一样return;else // 如果不相同{if (state == 1){if (to_state == 2)numbers.push_back(28);if (to_state == 3){numbers.push_back(28);numbers.push_back(28);}}if (state == 2){if (to_state == 1)numbers.push_back(27);if (to_state == 3)numbers.push_back(28);}if (state == 3){if (to_state == 1)numbers.push_back(27);if (to_state == 2)numbers.push_back(28);}}state = to_state;
}
int main()
{cin >> w >> s;cin >> init;const int begin_num[4] = {0, 'a', '0', 'A'};int state = 3; // 如果 state=1 小写 state=2 数字 state=3 大写for (int i = 0; i < init.size(); i++){convert_state(state, init[i]);numbers.push_back(init[i] - begin_num[state]);}if (numbers.size() % 2 == 1) // 如果是奇数{numbers.push_back(29);}code_word.push_back(0); // 先增加一个长度位for (int i = 0; i < numbers.size(); i += 2){code_word.push_back(30 * numbers[i] + numbers[i + 1]);}int k = -1;if (s != -1){k = 1;for (int i = 0; i < s + 1; i++){k *= 2;}}if ((code_word.size() + max(0, k)) % w != 0){int add_num = w - (code_word.size() + max(0, k)) % w;while (add_num > 0){code_word.push_back(900);add_num--;}}code_word[0] = code_word.size();if (s != -1){// 计算校验字// 模拟多项式除法vector<int> g; // g(x)的系数vector<int> d; // d(x)的系数// 初始化g(x)g.push_back(-3);g.push_back(1);int three = -9;for (int i = 2; i <= k; i++){vector<int> temp = g;g.insert(g.begin(), 0);for (int i = 0; i < temp.size(); i++){g[i] = (temp[i] * three) % 929 + g[i] % 929;g[i] % 929;}three = (three * 3) % 929;}// 初始化d(x)// 乘以x^kfor (int i = 0; i < k; i++){d.push_back(0);}for (int i = code_word.size() - 1; i >= 0; i--){d.push_back(code_word[i]);}// 模拟多项式除法// 要把dx的每一项都消除为0for (int i = d.size() - 1; i >= k; i--){int temp = -1 * d[i];d[i] = 0;for (int j = g.size() - 2; j >= 0; j--){d[i - (g.size() - 1 - j)] = (g[j] * temp) % 929 + d[i - (g.size() - 1 - j)] % 929;d[i - (g.size() - 1 - j)] %= 929;}}for (int i = k - 1; i >= 0; i--){int temp = (-1 * d[i]) % 929;code_word.push_back(temp >= 0 ? temp : temp + 929);}}for (int i = 0; i < code_word.size(); i++){cout << code_word[i] << endl;}return 0;
}

这篇关于【CSP】2021-12-3 登机牌条码 大模拟 字符串处理+模拟数学运算(多项式除法)完整代码+思路+遇到问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/809453

相关文章

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示