当前位置: 首页 > news >正文

关于网站设计的书西安做网站的云阔

关于网站设计的书,西安做网站的云阔,爱南宁app下载官网最新版,用jsp怎么做网站关键字:数学归纳法 一、题目 将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下: P A H N A P L S I I G Y I R …

关键字:数学归纳法

一、题目

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。

比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:

P   A   H   N
A P L S I I G
Y   I   R

之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,

比如:"PAHNAPLSIIGYIR"

请你实现这个将字符串进行指定行数变换的函数:

convert(s, numRows);

示例 1:

输入:s = "PAYPALISHIRING", numRows = 3
输出:"PAHNAPLSIIGYIR"

示例 2:

输入:s = "PAYPALISHIRING", numRows = 4
输出:"PINALSIGYAHRPI"
解释:
P     I    N
A   L S  I G
Y A   H R
P     I

示例 3:

输入:s = "A", numRows = 1
输出:"A"

二、思路:使用数学归纳法对Z字形排列进行规律总结

// 3阶Z变形 7个1

// 1    1

// 1 1 1

// 1    1

// 4阶Z变形 10个1

// 1         1

// 1     1  1

// 1  1     1

// 1         1

// 5阶Z变形 13个1

// 1            1

// 1        1  1 

// 1     1     1 

// 1  1        1 

// 1            1

// ........

// n阶Z变形

// 得到公式,n阶:3n-2个1,3n - 2 = n + (n-2) + n

经过以上归纳,我们知道了对于Z字变形的一个数学上的规律,这里的n就是题目中的numRows变量。同时从图形上看,我们可以把一个V形看成一个周期(如下图,表示3个周期),确定这个思想有利于理解后面的逻辑。

1            1             1

1        1  1         1  1        1

1     1     1      1     1     1

1  1        1   1        1   1

1            1             1

三、现在我们知道了这样一个规律,那么我们很容易想到把字符串按照这样的规律放进到一个二维数组里面,所以,我们需要基于我们发现的规律来分析出两个关键点:

  • 二维数组的行列数
  • 每一个字符在二维数组中的位置

四、实现步骤

1、定义一个二维数组,二维数组为arr[n-1][m-1],n为行数,m为列数,s为字符串

m = (Math.floor(s.length / (2n-2)))*(n-1) + (s.length % (2n-2)-n>0?(n-2)+1:(s.length % (2n-2) === 0?0:1);这里把(n + (n-2))看成一个周期

// 粗略一点的话,m也可以直接等于 Math.ceil(s.length/(2n - 2))*(n-1)

2、每个字符在二维数组中的位置(同样用到了数学归纳法)

 假设字符的索引为i:

所在列:col = (Math.floor((i+1) / (2n-2)))*(n-1) + ((i+1) % (2n-2)-n>0?(n-2)+1:((i+1) % (2n-2) === 0?0:1)

所在行:row = (i+1)%(2n-2) <=n?((i+1)%(2n-2)===0?2:(i+1)%(2n-2)):2n-(i+1)%(2n-2) 

3、 遍历字符串,把每个字符放在对应的位置上

4、再按行,从左到右取字符

五、完整代码

let convert = function(s,numRows = 3){let n = numRows;let len = s.length;let m = 0let arr = new Array(n);if(len < (3 * numRows - 2)){return s}m = (Math.floor(len/(2*n-2)))*(n-1)let remainder = len%(2*n-2)if(remainder !== 0){m += (remainder - n > 0?(n-2)+1:1)}for(let i = 0;i < n;i++){arr[i] = new Array(m);}// 遍历字符串for(let i = 0;i < len;i++){let remainder1 = (i+1)%(2*n-2)let col = (Math.floor((i+1)/(2*n-2)))*(n-1) + (remainder1-n>0?(n-2)+1:(remainder1 === 0?0:1))col = col -1 // 从0列开始let row = remainder1 <= n?remainder1:2*n-remainder1if(remainder1 === 0){row = 2}row = row - 1 // 从0行开始arr[row][col] = s[i]}// 按行从左向右取字符串let result = '';for(let i = 0;i < n;i++){for(let j = 0;j < m;j++){if(arr[i][j]){result += arr[i][j]}}}console.log(arr)console.log(result)
}
convert("PAYPALISHIRING",3) //输出:PAHNAPLSIIGYIR
convert("PAYPALISHIRING",4) //输出:PINALSIGYAHRPI

http://www.yayakq.cn/news/900407/

相关文章:

  • 网站开发与设计实训报告摘要网站改版业务
  • 如何在工商局网站上做网登怎么样做推广
  • 炫酷手机网站模板外国做家具的网站
  • 太阳宫网站建设开发前端后端
  • 网站开发哪里可做私活银锭网那个网站做的 好
  • 做黑网站吗知名的集团门户网站建设企业
  • 开原网站建设湖南大型网站建设公司
  • 建站平台系统广州品牌策划公司有哪些
  • 滨海新区建设和交通局网站手机版百度入口
  • 郑州众诚建设监理有限公司网站创建企业网站经过哪些步骤
  • 东莞网站案例营销什么主题和风格的网站好
  • 卖灯杆的做网站好榆林做网站的公司电话
  • 中山市规划建设局网站wordpress posts page
  • 网站后台搭建教程湖南网站营销seo多少费用
  • 51ppt模板免费下载网站做网站公司法人还要拍照吗
  • 如何做网站的内链优化ui设计公司
  • 新手做网站网页微信可以传文件吗
  • 做网站建设的网站网站开发的配置过程
  • 丝绸之路网站平台建设镇江网站定制
  • 马鞍山建设局网站物联网学什么
  • 保定网站建设推广厦门品牌网站建设
  • 国内做的比较好的二手网站无锡做网站设计
  • 广州网站建设维护如何开发电子商务网站
  • 网站开发需要哪些知识和工具制作网页实训报告
  • 锦州网站建设新闻网站怎么创建自己的网站
  • 网站开发免责说明wordpress英雄联盟
  • 咨询行业网站建设公司广州市建设注册中心网站
  • 免费企业网站管理系统惠州专业网站建设
  • 方维网站建设网站站点建立
  • 什么网站比较容易做哈尔滨网站建设哪家有