CCF-CSP 202112-3登机牌条码 解题思路+满分题解+详细注释

题目链接:202112-3登机牌条码

思路:

  • 第一步:按照题目顺序进行处理,即首先处理字符串,将对应的字符串转换成相应的数字编码,用t数组存储操作字符串后的数字,pre存储上一个字符的状态,j对应t数组的下标
  • 在转换时,有两点需要注意;1.在编码开始时,编码器处于大写字母模式; 2.小写模式不能直接转换成大写模式,必须经过数字模式过渡,对应的代码为t[j++]=28;//先转换成数字模式 t[j++]=28;//再转换成大写模式一定要注意此处需要存入两个28;同样,在数字模式转换成大写模式时,需要t[j++]=28;该过程只需要把表格看明白即可。
  • 如果有奇数个数字,即j为奇数时,需要在末尾补充29
  • 第二步:计算码字,重新开辟一个temp数组,r为temp数组的下标,按照公式30 x H + L对数组t进行计算,计算结果存入temp数组
  • 第三步:计算校验码字;当s为-1时,不需要计算校验码字,即k=0;其他情况,按照k = pow(2, s+1);计算k值
  • 全部的码字数量为存入数组temp中的数字总数r+长度码字1+校验码字k即sum = r+1+k
  • 然后判断sum是否可以被行宽w整除,如果不能被整除,需要在temp数组后填充900,直到行被填满
  • 需要理解输出样例中的第一个数字n(用于计算校验码字的数据码字)的来源: 填充后的temp数组中的数据个数r+长度码字1,即n = r+1;
  • 按照上述步骤处理后就可以拿到40分
  • 接下来,需要按照公式计算校验码字
    • 预处理公式: x^k d(x)≡q(x)g(x)-r(x);为了消除q(x)对计算r(x)的干扰,在恒等式两边同时对g(x)取余,则公式转换成x^k d(x) mod g(x) ≡ -r(x) mod g(x);
    • 问题转换成求x^k d(x) mod g(x);,最后对该式取反即可
    • 在求多项式带余除法时,给出一个样例:

      q(x)即为商,-r(x)为余数
    • 为了避免数据溢出,需要在计算过程中取模
    • 计算g(x)时考虑到每一次多项式乘以的因子都是 (x−a) 的格式, 所以可以把 A*(x−a)的多项式相乘转化为 xA−aA 的格式。 x*A 可以通过整体移项实现;在移项后,原本在 xi 的系数成为 xi+1 的系数
    • 在实际模拟d(x)和g(x)的代码中,建议大家带入具体例子进行理解
    • 取模时要先加上mod
  • 输出时,首先输出n,再输出temp数组中的值,再对数组d取反取模后输出

具体代码:

#include <iostream>
#include <math.h>
#include <algorithm>
#include <string.h>
using namespace std;
const int mod = 929,N = 1e5+10;
int w,s,k;
string str;//输入字符串
int t[N];//存储字符串对应的数
int temp[N];//存储码字结果,即对t数组操作后的数
int pre=1;//记录字符串当前的状态的上一个状态,1为大写字母,2为小写字母,3为数字
int g[N],d[N];//函数g(x),d(x);
int main()
{cin>>w>>s;cin>>str;//s==-1时,不需要计算校验字if(s==-1){k=0;}else{k = pow(2, s+1);}int j = 0;//记录t数组的下标//首先判断第一个字符的状态,设置pre的初始值//将后续字符串转换成数字for(int i=0;i<str.length();i++){//当前字符为大写字母if(str[i]>='A'&&str[i]<='Z'){if(pre==1)//上一个字符为大写字母{t[j++]=str[i]-'0'-17;//直接转化pre=1;}else if(pre==2)//上一个字符为小写字母{t[j++]=28;//先转换成数字模式t[j++]=28;//再转换成大写模式t[j++]=str[i]-'0'-17;//再转换pre=1;}else if(pre==3)//上一个字符为数字{t[j++]=28;t[j++]=str[i]-'0'-17;pre=1;}}else if(str[i]>='a'&&str[i]<='z')//当前字符为小写字母{if(pre==1)//上一个字符为大写字母{t[j++]=27;//先存入小写模式t[j++]=str[i]-'0'-49;//转换成小写模式pre = 2;}else if(pre==2)//上一个字符为小写字母{t[j++]=str[i]-'0'-49;pre = 2;}else if(pre==3)//上一个字符为数字{t[j++]=27;//先存入小写模式t[j++]=str[i]-'0'-49;//转换成小写模式pre = 2;}}else if(str[i]>='0'&&str[i]<='9')//当前字符为数字{if(pre==1)//上一个字符为大写字母{t[j++]=28;//先转换成数字模式t[j++]=str[i]-'0';pre=3;}else if(pre==2)//上一个字符为小写字母{t[j++]=28;//先转换成数字模式t[j++]=str[i]-'0';pre=3;}else if(pre==3)//上一个字符为数字{t[j++]=str[i]-'0';pre=3;}}}if(j%2==1)//如果有奇数个{t[j++]=29;//结尾添加29}int r=0;//temp数组下标for(int i=0;i<j;i+=2){temp[r++]=t[i]*30+t[i+1];}int sum = r+1+k;//全部的码字数量int x = sum%w;//判读sum是否可以被行宽整除if(x!=0){for(int i=0;i<w-x;i++){temp[r++]=900;}}int n = r+1;//计算g(x),按照降次存入系数g[0] = 1;int a = -3;for (int i=1;i<=k;a=a*3%mod,i++){for (int j=i-1;j>=0;j--)//逆序计算{g[j+1]=(g[j+1]+g[j]*a)%mod;//关键代码,建议自己实际模拟一次}}//计算d(x)d[0]=n;//第一个数for(int i=1;i<=r;i++){d[i]=temp[i-1];//将先前得到的temp数组存入函数d中}for(int i=0;i<=r;i++){int x = d[i];d[i]=0;for(int j=1;j<=k;j++){d[i+j]=(d[i+j]-x*g[j])%mod;//关键代码,建议自己实际模拟一次}}cout<<n<<endl;for(int i=0;i<r;i++){cout<<temp[i]<<endl;}for(int i = r+1;i<=r+k;i++){cout<<(-d[i]%mod+mod)%mod<<endl;//取反后输出,注意要取模时要加上mod}return 0;
}
//4 -1
//HELLO
//4
//214
//341
//449//4 0
//HE1lo
//6
//214
//841
//821
//449
//900
//229
//811

CCF-CSP 202112-3登机牌条码 解题思路+满分题解+详细注释相关推荐

  1. CCF CSP 201812-2 小明放学 解题思路及经验总结

    更新:多谢weixin_44714465同学指出我的错误[详见49-52行代码,已改正!].CCF CSP的OJ居然没有把这个错误检测出来,不过为了追求严谨,我们还是应该及时改正! 题目描述 试题编号 ...

  2. CCF-CSP-202112-3:登机牌条码(C++11题解)

    文章目录 问题描述 解题思路 数学基础 模拟思路 得分技巧 AC代码 问题描述 题目来源:CCF-CSP-202112-3:登机牌条码 解题思路 数学基础 需要一些很简单的数论基础知识(主要是同余的知 ...

  3. CCF-CSP 201812-1小明上学 简单思路 满分题解

    CCF-CSP 201812-1小明上学 简单思路 满分题解 题目链接:CCF-CSP 201812-1小明上学 思路: 1.红绿灯的变化顺序为红->绿->黄. 2.根据小明到达路口时红绿 ...

  4. CCF- CSP 202212-2训练计划 详细思路 满分题解(结尾附自编测试用例)

    CCF- CSP 202212-2训练计划 详细思路 满分题解 题目链接:CCF- CSP 202212-2训练计划 思路: 测试数据满足0<n<365,0<m<100,一般情 ...

  5. 洛谷P5082 成绩解题思路及题解

    讨论 858 通过 3.6K 提交 题目提供者 vercont 评测方式 云端评测 标签 难度 入门难度 时空限制 1000ms / 128MB 提交 题解 提示:收藏到任务计划后,可在首页查看. 最 ...

  6. fileinclude-宜兴网信办解题思路--呕心沥血--非常详细!

    第一步-分析题目: 打开题目场景,如下图: 这上面显示说,flag在这个/var/www/html/flag.php文件中.由此可知,这道题是文件包含题. 明确了目标,咱们在场景那个页面按下F12来看 ...

  7. CCF CSP——202206-5 PS无限版(70分题解)

    问题描述 试题链接:PS无限版 70分题解 题目还是比较简单的,不至于长篇大论的(读题都累死人了),此题要求:有一系列的点(用数组保存下来),编号(1,2--,n),对编号[l,r]的点进行不同的7个 ...

  8. 双指针法(leetcode分类解题,C++代码详细注释)

    双指针法 前言 167.两数之和 II - 输入有序数组 88.合并两个有序数组 142. 环形链表 II 633.平方数之和 680. 验证回文字符串 Ⅱ 27. 移除元素 344. 反转字符串 剑 ...

  9. 贪心算法(leetcode分类解题,C++代码详细注释)

    贪心算法 前言 455.分发饼干 135.分发糖果 435.无重叠区间 605.种花问题 452.用最小数量的箭引爆气球 763.划分字母区间 122. 买卖股票的最佳时机 II 376. 摆动序列 ...

最新文章

  1. php curl 内容采集
  2. Spring使用webjar
  3. 疯狂ios讲义疯狂连载之加载界面的图片
  4. Linq to xml:使用 XSLT 转换 XML 树
  5. html导出pdf实例,jsPDF导出pdf示例
  6. 不叫K50 Pro+!Redmi K50系列超大杯或有新名称
  7. python取文件后缀
  8. 《JavaScript函数式编程思想》——从面向对象到函数式编程
  9. 零基础学习 iOS 开发?如何系统学习 iOS ?
  10. .NET下使用snappy
  11. php云打印类,PHP应用:PHP云打印类完整示例
  12. 【追剧达人JAVA修复版】苹果CMS10原生APP修改版 影视APP源码附安装教程
  13. Ubuntu16.04 Flash Player播放插件安装
  14. VMware16虚拟机:在Windows10系统下---安装VMware tools
  15. 武林秘籍之C语言大法.第二式 语句 带你走向武林之巅
  16. day11-函数作业
  17. Android下拉刷新
  18. 朴素贝叶斯 二项式 伯努利
  19. Win10使用WMIC提示“WMIC已弃用”
  20. DataGrip 初级与高级教程(仅提供链接)

热门文章

  1. 程序猿如何找到自己心仪的对象?
  2. 在ObjectARX中使用MFC-使用MfcGridCtrl
  3. L1距离和L2距离图像解释
  4. aws beanstalk 使用eb cli配置和启动环境
  5. 甲方安全开源项目清单
  6. 计算机考研报录比10比1,2020考研报录比高达10:1!2021择校应避开哪些重灾区?
  7. 【服务器搭建个人网站】教程五:手把手教你怎样进行公安备案 快来学~
  8. 命令行查看笔记本电脑电池使用状态
  9. (4)图像增强- Part1. 对比度增强
  10. 监控软件Zabbix之配置139邮箱报警机制