Live archive 5696 - Hexadecimal View(模拟)

题意:按照格式输出字符串的16进程数,再转换大小写。。

这是去年大连赛区的题,只会一道最水的题。。无语了。。其他的题,看了别人的代码也不会。。。。


#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
using namespace std;
char a[5009],b[20];
void out(int k,char b[],int j)
{

    printf("%03d0:",k);
    for(int i=0;i<j;i++)
    {
        if((i&1)==0) printf(" ");
        printf("%x",b[i]);
    }
    for(int i=0;i<17;i++)
    {
        if(b[i]>='a'&&b[i]<='z')
        b[i]=b[i]-'a'+'A';
        else if(b[i]>='A'&&b[i]<='Z')
        b[i]=b[i]-'A'+'a';
    }
    for(int i=j;i<16;i++)
    {
        if((i&1)==0) printf(" ");
        printf("  ");
    }printf(" ");
    b[j] = '\0';
    printf("%s\n",b);
}
int main()
{
    freopen("in.txt","r",stdin);
    while(gets(a))
    {
        ;
        if(strlen(a)<=0) break;
        int len = strlen(a);
        int k = 0,j;
        for(int i=0;i<len;i++)
        {
            for(j=0;j<16&&i<len;j++,i++)
            {
                b[j] = a[i];
            }i--;
            out(k++,b,j);
        }
    }
    return 0;
}


你可能感兴趣的:(Live archive 5696 - Hexadecimal View(模拟))