首页 > 其他 > 详细

SOJ 1036. Crypto Columns

时间:2015-10-05 23:12:15      阅读:338      评论:0      收藏:0      [点我收藏+]

题目大意:一个字符串,去掉空格和符号后变成"plaintext"。另一个字符串叫"keyword"。将plaintext排成多行,每行有keyword.size的宽度,不能排满一列的用别的字符填满,生成了字符矩阵。每次选取keyword中字典序最小的字符对应的列,作为需要选取的矩阵的列,被选择过的字符不再被选择,最后形成一行新的字符串,作为输出字符串。
解题思路:对keyword中的字符及其对应的列进行排序,利用排序结果还原成字符矩阵,然后按行输出字符矩阵。
代码如下:

 1 #include <iostream>
 2 #include <string>
 3 #include <vector>
 4 using namespace std;
 5 
 6 const int COLS = 15;
 7 const int ROWS = 105;
 8 
 9 string kw;
10 string ct;
11 
12 char m[ROWS][COLS];
13 
14 void init() {
15     for (int i = 0; i < ROWS; i++) {
16         for (int j = 0; j < COLS; j++) {
17             m[i][j] = 0;
18         }
19     }
20 }
21 
22 struct Elem {
23     char ch;
24     int col;
25 };
26 
27 Elem elems[COLS];
28 
29 bool cmp(const Elem & e1, const Elem &e2) {
30     /*if (e1.ch > e2.ch) {
31         return true;
32     } else if (e1.ch < e2.ch) {
33         return false;
34     } else {
35         if (e1.col > e2.col) {
36             return true;
37         } else if (e1.col < e2.col){
38             return false;
39         } else {
40             return false;
41         }
42     }*/
43 
44     return (e1.ch > e2.ch) || (e1.ch == e2.ch && e1.col > e2.col);
45 }
46 
47 int main() {
48     string end = "THEEND";
49 
50     while (cin >> kw, kw != end) {
51         cin >> ct;
52         int c = kw.size();
53         int r = ct.size() / kw.size();
54 
55         for (int i = 0; i < c; i++) {
56             elems[i].ch = kw[i];
57             elems[i].col = i;
58         }
59 
60         for (int i = 0; i < c; i++) {
61             for (int j = 0; j < c - i - 1; j++) {
62                 if (cmp(elems[j], elems[j + 1])) {
63                     Elem elem = elems[j];
64                     elems[j] = elems[j+1];
65                     elems[j+1] = elem;
66                 }
67             }
68         }
69 
70         for (int i = 0; i < c; i++) {
71             int begin = r * i;
72             //int end = begin + r;
73             int col = elems[i].col;
74 
75             for (int j = 0; j < r; j++) {
76                 m[j][col] = ct[begin + j];
77             }
78         }
79 
80         for (int i = 0; i < r; i++) {
81             for (int j = 0; j < c; j++) {
82                 cout << m[i][j];
83             }
84         }
85 
86         cout << endl;
87     }
88 
89     return 0;
90 }

 

SOJ 1036. Crypto Columns

原文:http://www.cnblogs.com/mchcylh/p/4856348.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!