20 反反覆覆

2021-08-07 12:52:36 字數 1100 閱讀 9936

/*

name: 20_反反覆覆

author: 巧若拙

description:

描述mo和larry發明了一種資訊加密方法。他們首先決定好列數,然後將資訊(只包含字母)從上往下依次填入各列,

並在末尾補充一些隨機字母使其成為乙個完整的字母矩陣。

例如,若資訊是「there's no place like home on a snowy night」並且有5列,mo會寫成:

t o i o y

h p k n n

e l e a i

r a h s g

e c o n h

s e m o t

n l e w x

注意mo只會填入字母,且全部是小寫形式。在這個例子中,mo用字母「x」填充了資訊使之成為乙個完整的矩陣,

當然他使用任何字母都是可以的。

mo根據這個矩陣重寫資訊:首先從左到右寫下第一行,然後從右到左寫下第二行,再從左到右寫下第三行……

以此左右交替地從上到下寫下各行字母,形成新的字串。

這樣,例子中的資訊就被加密為:toioynnkpheleaigshareconhtomesnlewx。

你的工作是幫助larry從加密後的資訊中還原出原始資訊(包括填充的字母)。

輸入第一行包含乙個整數(範圍2到20),表示使用的列數。

第二行是乙個長度不超過200的字串。

輸出一行,即原始資訊。

樣例輸入

5toioynnkpheleaigshareconhtomesnlewx

樣例輸出

theresnoplacelikehomeonasnowynightx

*/#include #include using namespace std;

const int m = 20;

const int n = 100;

char a[n][m], b[n][m];

int main()

} n = s.length() / m; //行數

for (int j=0; jcout << endl;

return 0;

}

20 反反覆覆

總時間限制 1000ms 記憶體限制 65536kb 描述mo和larry發明了一種資訊加密方法。他們首先決定好列數,然後將資訊 只包含字母 從上往下依次填入各列,並在末尾補充一些隨機字母使其成為乙個完整的字母矩陣。例如,若資訊是 there s no place like home on a sn...

OpenJudge 反反覆覆

描述 mo和larry發明了一種資訊加密方法。他們首先決定好列數,然後將資訊 只包含字母 從上往下依次填入各列,並在末尾補充一些隨機字母使其成為乙個完整的字母矩陣。例如,若資訊是 there s no place like home on a snowy night 並且有5列,mo會寫成 t o ...

百練noi 20 反反覆覆

總時間限制 1000ms 記憶體限制 65536kb 描述 mo和larry發明了一種資訊加密方法。他們首先決定好列數,然後將資訊 只包含字母 從上往下依次填入各列,並在末尾補充一些隨機字母使其成為乙個完整的字母矩陣。例如,若資訊是 there s no place like home on a s...