比如一个3进制的数组: [1 1 2 2 2 0 0] 用一个字符串表示。。。

此类题目要明白两点:

1. 打表:用数组下标索引字符。同一时候注意假设从字符相应回数字:

int index = (str[i] >= '0' && str[i] <= '9') ? (str[i]-'0'-radix):(str[i]-'a'-radix + 10);

2. 注意低位在前还是高位在前,假设先来的是 低位*radix^i 就可以。

3. 统计每几个radix进制数组成一位。利用bits来表示。

。。

这破题主要是麻烦。。

#include <assert.h>
#include <algorithm>
#include <vector>
using namespace std;
const int radix = 3;
string base = "";
string compress(const vector<int>& arr) {
string res = "";
int i, j, size = arr.size(), left, bits;
vector<int> base;
for (i = 1, j = 0; i*radix+radix < 36; i *= radix, j++); // 剩余部分保持不变,直接追加到结尾
bits = j;
left = size - size / bits * bits;
size -= left;
for (char ch = '0'; ch <= '9'; ++ch)
base.push_back(ch);
for (char ch = 'a'; ch <= 'z'; ++ch)
base.push_back(ch);
for (i = 0; i < size; i += bits) {
int tmp = 0, t = 1; for (j = 0; j < bits; ++j) {
tmp += arr[i+j]*t;
t *= radix;
}
res += base[radix + tmp];
}
for (j = 0; j < left; ++j)
res += base[arr[i+j]];
return res;
}
vector<int> depress(const string& str) {
vector<int> res;
int i, j, len = str.length(), idx, bits;
for (i = 1, j = 0; i*radix+radix < 36; i *= radix, j++); // 剩余部分保持不变。直接追加到结尾
bits = j;
for (i = 0; i < len; ++i) {
idx = str[i] >= 'a' && str[i] <= 'z' ? (str[i] - 'a' + 10) : (str[i] - '0');
if (idx < radix) {
res.push_back(idx);
}
else {
idx -= radix;
for (j = 0; j < bits; ++j) {
res.push_back(idx%radix);
idx /= radix;
}
}
}
return res;
}
int main() {
int arr[] = {0,1,2,2,2,2,1,1,1,2,0,0,0,0,0,1};
vector<int> vec(arr, arr+sizeof(arr)/sizeof(int));
string str = compress(vec);
vector<int> res = depress(str);
return 0;
}

以下的代码多了非常多没用的控制字符,不知道为啥。

。。

#include <assert.h>
#include <algorithm>
#include <vector>
using namespace std;
const int radix = 4;
string base = "";
string compress(const vector<int>& arr) {
  string res = "";
  
  int i, j, size = arr.size(), left, bits;
  
  for (i = 1, j = 0; i*radix + radix < 36; i *= radix, ++j);
  bits = j;
  left = size - size / bits * bits;
  size = size / bits * bits;   for (char ch = '0'; ch <= '9'; ++ch)
    base.push_back(ch);
  for (char ch = 'a'; ch <= 'z'; ++ch)
    base.push_back(ch);
  for (i = 0; i < size; i += bits) {
    int index = 0, t = 1;
    for (j = 0; j < bits; ++j) {
      index = index + arr[i+j]*t;
      t *= radix;
    }           
    res.push_back(base[radix+index]);
  }
  for (i = 0; i < left; ++i)
    res.push_back(arr[size+i]+'0');
  return res; 
} vector<int> depress(const string& str) {
  int len = str.length(), i = 0, j, bits;
  for (i = 1, j = 0; i*radix + radix< 36; i *= radix, ++j);
  bits = j;
  vector<int> res;
  for (i = 0; i < len; ++i) {
    if (str[i]-'0' >= 0 && str[i]-'0' < radix) 
      res.push_back(str[i]-'0');
    else {
      int index = (str[i] >= '0' && str[i] <= '9') ? (str[i]-'0'-radix):(str[i]-'a'-radix + 10);      
      for (j = 0; j < bits; ++j) {
        res.push_back(index%radix);
        index = index/radix;
      }
    }
  }
  return res;

int main() {   int arr[] = {0,1,2,2,2,2,1,1,1,2,0,0,0,0,0,1};
  vector<int> vec(arr, arr+sizeof(arr) / sizeof(int));   string str = compress(vec);
  vector<int> res = depress(str);   return 0;
}

最新文章

  1. python之最强王者(11)——异常(exception)
  2. IDEA 配置 tomcat的数据源
  3. oracle(sql)基础篇系列(二)&mdash;&mdash;多表连接查询、子查询、视图
  4. HDU 5010 Get the Nut(2014 ACM/ICPC Asia Regional Xi&#39;an Online)
  5. Ajax学习记录
  6. 拿到阿里,网易游戏,腾讯,smartx的offer的过程
  7. Windbg符号与源码 《第二篇》
  8. 【OpenCV】opencv3.0中的SVM训练 mnist 手写字体识别
  9. jsp中JavaBean的用法
  10. linux包之iproute之ip命令
  11. UDP protocol
  12. HTTP学习笔记3-响应结构
  13. 查看实时公网ip
  14. JAVA日期字符串转化,日期加减
  15. 母亲的牛奶(milk)
  16. Android4.4KitKat支持u盘功能
  17. 什么是Css Hack?ie6,7,8的hack分别是什么?
  18. centos7服务器无GUI情况下安装使用Xvfb、selenium、chrome和selenium-server
  19. HTML5是什么,以及优点和缺点
  20. POJ 2299 Ultra-QuickSort 离散化加树状数组求逆序对

热门文章

  1. 数据分析≠Hadoop+NoSQL
  2. AsyncTask简单入门
  3. urlrewrite 匹配规则之优先选择
  4. linux查看端口和进程
  5. Swift中的ViewController
  6. JVM --java 字节码的结构解析
  7. 基于visual Studio2013解决C语言竞赛题之0810链表去重
  8. AV_百度百科
  9. android 调用系统打电话和发短,懒得记
  10. (step6.1.5)hdu 1233(还是畅通工程——最小生成树)