2 1 Mike 4 Mike
Case #1: TWlrZQ== Case #2: Vmtaa2MyTnNjRkpRVkRBOQ==
题意:将3个8位变成4个6位,不足八位的时候补0,最后不足四位补=,求出k次变换后的结果
#include <bits/stdc++.h>
using namespace std;
const int N = 10005;
char e[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
//int main()
//{
// int k=11;
// for(int i=7;i>=0;i--)
// cout<<(k>>i&1);
// cout<<endl;
// //00001011
//
// k=(11<<8);
//
// for(int i=15;i>=0;i--)
// cout<<(k>>i&1);
// cout<<endl;
// //0000101100000000
//
// return 0;
//}
void base64(char s[])
{
char t[N]={0};//要加一个对数组的初始化。
int l=strlen(s);
int p=0;
int a=0;
int r=l%3;
for(int i=0;i<l;i+=3)
{
int k=(((int)s[i])<<16)+(((int)s[i+1])<<8)+(int)(s[i+2]);//每次取三个字节
int cb=1;
for(int j=0;j<24;j++)
{
a+=(k>>j&1)*cb;
cb<<=1;
if(j%6==5)
{
t[p++]=e[a];
a=0;
cb=1;
}
}
swap(t[p-1],t[p-4]);//4位字符是反的,比如AAA (100000101000001010000010)每6位一组后是BFUQ 倒过来后是QUFB 正常AAA应该是(010000010100000101000001)从左到右六个一组就是QUFB swap(t[p-2],t[p-3]);
}
if(r==1)
t[p-1]=t[p-2]='=';
if(r==2)
t[p-1]='=';
memcpy(s,t,sizeof(char)*N);
}
int main()
{
int cas, n;
scanf("%d", &cas);
char s[N];
for(int k = 1; k <= cas; ++k)
{
memset(s,0,sizeof(s));
scanf("%d%s", &n, s);
while(n--)
base64(s);
printf("Case #%d: %s\n", k, s);
}
return 0;
}
/*
0123456789012345678901234567890123456789012345678901234567890123
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/
*/
原文:http://blog.csdn.net/wust_zjx/article/details/46361479