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

wordpress建手机站dede5.7微电影网站模板

wordpress建手机站,dede5.7微电影网站模板,.中国域名的网站,产品网页设计教程目录 🎈了解题意 🎈算法原理 🚩先处理第一行和最后一行 🚩再处理中间行 🎈实现代码 🎈了解题意 大家看到这个题目的时候肯定是很迷茫的,包括我自己也是搞不清楚题目什么意思,我…

目录

🎈了解题意

🎈算法原理

🚩先处理第一行和最后一行

🚩再处理中间行

🎈实现代码


🎈了解题意

大家看到这个题目的时候肯定是很迷茫的,包括我自己也是搞不清楚题目什么意思,我们静下心来看看我来给大家说透彻这个题目的意思。

我们输入字符串"ABCDEFGHIJKL",行数是四行时,我们是按照Z字形排列。先向下排四行,然后斜向上排列到四行之后,然后向下排列四行......。(我们用一块一块的方格来填字符)

然后我们输出的是像数组一样遍历 输出结果是 AGBFHLCEIKDJ 字符串。


🎈算法原理

我们举例输入的是   ABCDEFGHIJKMNOP  这段字符串,我们输出的字符串就是从第一行第一列遍历到最后一行最后一列。

🚩先处理第一行和最后一行

我们从第一行分析,我们看到 AGM之间的距离 A和G之间的距离是6,G与M之间的距离是6,我们就可以看到对于第一行来说,我们只需要循环从0开始,每次+6,就给新字符串更新结果。6是相当于公差d=6,6是怎么来的呢?

我们的公差6其实相当于,将F向左移一列,然后俩列一共是8个元素,然后减去2个空格就是公差了那么我们就衍生一个公式  公差d=2n-2 (n代表行数),举一个例子当然是不能足以证明结果,我们给n设定3行,我们看看第一行公差是不是d=2*3-2=4.

我们看到,d=2n-2,n等于3的时候d=4,公差是4,确实验证了我们的猜想。所以第一行每个元素的相差的距离是2n-2的距离(n代表行数)

        string ret;//定义个最终字符串结果int d=2*numRows-2,n=s.size();//公差为2n-2,n代表原字符串的长度//1.先处理第一行for(int i=0;i<n;i+=d)//每次都加上公差{ret+=s[i];//更新结果}

 同样的,我们看到最后一行其实和第一行是同样的原理。

        //处理最后一行for(int i=numRows-1;i<n;i+=d){ret+=s[i];}

🚩再处理中间行

我们看到BHN绿色线指向的,B和H相差6,H和N相差6,和第一行和最后一行一样的思路,那么我们中间的FL和EK紫色线画的,我们看到F和L相差的结果也是6,EK相差的结果也是6,所以还是再循环的时候加上公差d,那么我们如何确定F和E下标的值呢?还是和上面一样的,我们是如何计算公差的呢?移动数据。字符在哪一列,我们就看前面列数的总空格数减去空白格即可。

  • G= 前面有3列一共有3*4=12格  减去  前面列数的空格数6 = 6 字符G的下标是处在原字符串下标6的位置
  • F= 前面有2列一共有2*4=8格  减去  前面列数的空格数3  =5 字符F的下标是处在原字符串下标5的位置

那么F相当于2n-3=5(n等于4,三个空格),E相当于n-0=4 (n等于4,0格空格)

我们如何确定F和E的开始值呢?

对于第二行 F的下标是5,公差是6, 相当于6-1=5

对于第三行 E的下标是4 ,公差是6   相当于6-2=4

所以我们进行依次循环,处理中间行,从k=1开始,第二行的第二个元素是d-k,到k=2时,第三行的第三个元素是d-k,然后当k=n-1=3的时候就结束了,因为第四行是最后一行。

     for(int k=1;k<numRows-1;k++){for(int i=k,j=d-k;i<n||j<n;i+=d,j+=d){if(i<n)ret+=s[i];if(j<n)ret+=s[j];}}

我们是先让i对应的值先更新,然后再更新j对应的值,条件是i<n或者j<n,因为只要其中一个满足的话,我们还是要更新结果。下面要进行判断,否则就重复更新了。 


🎈实现代码

class Solution {
public:string convert(string s, int numRows) {if(numRows==1)return s;string ret;int d=2*numRows-2,n=s.size();//1.先处理第一行for(int i=0;i<n;i+=d){ret+=s[i];}//2.处理中建行for(int k=1;k<numRows-1;k++){for(int i=k,j=d-k;i<n||j<n;i+=d,j+=d){if(i<n)ret+=s[i];if(j<n)ret+=s[j];}}//处理最后一行for(int i=numRows-1;i<n;i+=d){ret+=s[i];}return ret;}
};

开学坏,见面好。

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

相关文章:

  • 郑州网站建设金麦建站优化网站推广
  • 中英双语网站各类郑州网站建设
  • 专业网站建设提供商微信推广赚钱
  • 昆明房产网站建设wordpress 微信朋友圈
  • 17做网站郑州商城网站建设价格最优
  • 企业网站 源代码移动互联网开发方向要学什么
  • 建设苏州旅游网站的方案策划书自己做ppt网站吗
  • 天津网站建设论坛银川免费网站建设
  • 昆明做网站首选互维搜索引擎优化的简称
  • 京东物流网站建设特点免备案主机
  • 湖州企业做网站网站建设-英九网络
  • 响应式网站开发原则全包圆整体家居体验馆
  • 群晖 wordpress 怎么映射到外网seo关键词优化软件合作
  • 网站优化qq群whois域名查询官网
  • 怎么做qq代刷网站深圳企业网站制作公司
  • 深圳商城网站哪家做的好苏州要服务网站建设
  • 在哪里建设网站wordpress 网站制作
  • 宜昌外贸网站建设优化推广贵卅省住房和城乡建设厅网站
  • 网站开发对企业的关键请为hs公司的钻石礼品网站做网络营销沟通策划_预算是20万.
  • 手机网站自助建设南京斯点企业网站建设
  • 网站建设整个流程图建个私人网站怎么做
  • Paas网站建设wordpress加入百度统计
  • asp.net企业网站wordpress vip付费
  • 零食网站模板谷歌seo外包公司哪家好
  • seo网站权重网站首页设计教程
  • 网站开发兼容问题上海建设银行官网网站
  • 广东工程建设监理有限公司网站有限责任公司和有限公司有啥区别
  • 免费网站制作网站源码网站规划与建设大作业答案
  • 在线营销单页网站制作室内装修设计联盟
  • 珠宝首饰网站建设用vue开发好看的官网