算法竞赛入门经典 回文词 UVa401 msg数组

2024-02-03 03:18

本文主要是介绍算法竞赛入门经典 回文词 UVa401 msg数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里不讲解题讲答案里的一个细节就是msg数组的作用及原理.

作者在书中没有直接说明msg数组的作用及原理我这里就简明讲解下.

首先, msg作为一个字符串数组.

msg[0]就对应 “not a palindrome”, 1就对应 “a regular palindrome”, 依些类推下标的所有取值[0,3]

刚好4个数值对应4个状态.

有朋友可能会问这里为啥不这样写呢?

If(p)
{if(m)//状态3, p!=0 && m!=0else//状态1, p!=0 && m==0}
else
{if(m)//状态2, p==0 && m!=0else//状态0, p==0 && m==0
}


这样写没错但代码冗长明显可以优化.

学过linux的朋友可能就知道, linux的文件权限rwx, 对应的数字就是421, 而且每个[0,7]的数字可以唯一对应一种权限.

7    rwx

6    rw-

5    r-x

4    r--

3    -wx

2    -w-

1    --x

唉嘛是不是有点像二进制01.

是的化成01就变成这样了

7    rwx    111

6    rw-    110

5    r-x    101

4    r--    100

3    -wx    011

2    -w-    010

1    --x    001

是的这里的m*2+p就是这个原理作者在初始化的时候mp都置为1. 就是判断前默认是回文串和镜像串.

为什么m要乘以2 ? 学过进制转换吧二进制转10进制的时候比如有k位 0表示最低位, num(i)表示这个数字的第i.

Ans = num(0)*2^0 +num(1)*2^1+num(2)*2^2+...+num(k-2)*2^(k-2)+num(k-1)*2(k-1)

所以2进制的权从低位到高位为1,2,4,8,16,32…

我们这里用二进制的2个位就能表示2*2=4个状态.

linux文件权限用了3个位所以4,2,1,就是这么来的.

打个表吧:

m    p    m*2+p(D)    m*2+p(B)

0    0    0                        00

0    1    1                        01

1    0    2                        10

1    1    3                        11

D表示10进制, B表示2进制.

源代码:

// UVa401 Palindromes
// Rujia Liu
#include<stdio.h>
#include<string.h>
#include<ctype.h>
const char* rev = "A   3  HIL JM O   2TUVWXY51SE Z  8 ";
const char* msg[] = {"not a palindrome", "a regular palindrome", "a mirrored string", "a mirrored palindrome"};char r(char ch) {if(isalpha(ch)) return rev[ch - 'A'];return rev[ch - '0' + 25];
}int main() {char s[30];while(scanf("%s", s) == 1) {int len = strlen(s);int p = 1, m = 1;for(int i = 0; i < (len+1)/2; i++) {if(s[i] != s[len-1-i]) p = 0; // 不是回文串if(r(s[i]) != s[len-1-i]) m = 0; // 不是镜像串}printf("%s -- is %s.\n\n", s, msg[m*2+p]);}return 0;
}

这篇关于算法竞赛入门经典 回文词 UVa401 msg数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

SpringCloud Stream 快速入门实例教程

《SpringCloudStream快速入门实例教程》本文介绍了SpringCloudStream(SCS)组件在分布式系统中的作用,以及如何集成到SpringBoot项目中,通过SCS,可... 目录1.SCS 组件的出现的背景和作用2.SCS 集成srping Boot项目3.Yml 配置4.Sprin

SpringMVC配置、映射与参数处理​入门案例详解

《SpringMVC配置、映射与参数处理​入门案例详解》文章介绍了SpringMVC框架的基本概念和使用方法,包括如何配置和编写Controller、设置请求映射规则、使用RestFul风格、获取请求... 目录1.SpringMVC概述2.入门案例①导入相关依赖②配置web.XML③配置SpringMVC

MySQL索引踩坑合集从入门到精通

《MySQL索引踩坑合集从入门到精通》本文详细介绍了MySQL索引的使用,包括索引的类型、创建、使用、优化技巧及最佳实践,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录mysql索引完整教程:从入门到入土(附实战踩坑指南)一、索引是什么?为什么需要它?1.1 什么

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成