//sicily 1036.Crypto Columns,
#include <iostream>
#include <string>
#include <stdio.h>
using namespace std;
/*
typedef struct Link//将keyword中的
{
char c;
int column;
}Link;
*/
int main()
{
//char result[10][10];
string s1 = "";
while(cin >> s1 && s1 != "THEEND")
{
int flag = 0;//判断找到的字母个数
char result[100][100] = {""};
string s2,s3;
s3 = s1;
cin >> s2;
int raw = s2.length() / s3.length();//对应的2维数组所能组成的行数
for(char i = 'A';i <= 'Z';i++)//对keyword的每个char进行判断
{
for(int j = 0;j < s3.length();j++)
{
if(s3.at(j) == i)//如果s1[j]中的某个字符与i对应,则j为此字母对应的列下标
{
flag++;//找到一个字母
int r = 0;//表示二维数组的行标
for(int k = (flag - 1) * raw;k < (flag - 1) * raw + raw;k++)//将s2中对应的一段字符串复制到二维数组的第j列中
{
result[r][j] = s2[k];
//printf("%c,%d,%d\n",result[r][j],r,j);
r++;
}
}
}
}
//输出二维数组
for(int i = 0;i < raw;i++)
for(int j = 0;j < s3.length();j++)
printf("%c",result[i][j]);
cout << endl;
}
return 0;
}
sicily 1036.Crypto Columns
最新推荐文章于 2016-05-22 18:59:49 发布