6. ZigZag Conversion

 The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (you may want to display this pattern in a fixed font for better legibility)

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

And then read line by line: "PAHNAPLSIIGYIR"

Write the code that will take a string and make this conversion given a number of rows:

string convert(string text, int nRows);

convert("PAYPALISHIRING", 3) should return "PAHNAPLSIIGYIR". 

通过画图找规律

/**
  由规律来看

  第i排开始的数下标是i;
  第一排和最后一排 的间距为 2*(N-1);
  其他排的间距为 分别是2*(m-i) 2*(i-1)

*/


#include<iostream>
using namespace std;
class Solution {
public:
    string convert(string s, int numRows) {
        int length = s.size();
        string result;//用于输出排序后的字符串
        if ((numRows == 1) || (numRows>=length))

            return s;

        for (int i = 0; i < numRows; i++)
        {
            int j = i;
            bool flag=true;
            while (j < length)
            {
                result.push_back(s.at(j));//将排好序的字符插入到result中
                if (i == 0 || i == numRows - 1)
                {
                    j += 2 * (numRows - 1);


                }
                else
                {
                    if (flag)
                    {
                        j +=  2 * (numRows - 1-i);

                        flag = false;
                    }
                    else
                    {
                        j +=  2 * i;
                        flag = true;
                    }



                }
            }

        }

        return result;
    }
};





int main()
{
    Solution s1;
    string result=s1.convert("abcd", 2);
    for (int i = 0; i <result.size(); i++)
    {
        cout << result[i] << ' ';
    }





    system("pause");

}

a c

b d

a c b d 请按任意键继续. . .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值