首页 > 其他 > 详细

ZOJ Problem Set - 3713

时间:2014-03-23 22:13:25      阅读:491      评论:0      收藏:0      [点我收藏+]

题意:给定一个字符串,用字符串ASC2码16进制数输出 ,并在前面输出字符串长度的16进制,输出长度的规则是 先输出长度的二进制数的后七位的十六进制(如果左边还有1 则这在后七位前面加上个1再输出  然后二进制数右移动七位,直到左边没有1)   注:所有16数都必须为两位!

解题思路:对长度进行输出处理

解题代码:

bubuko.com,布布扣
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<time.h>
#include<math.h>
char str[3000005];
int bi[100];
void print(int x)
{
   if (x < 10)
       printf("0%d",x);
   else if(x < 16)
       printf("0%c",A+(x-10));
   else
   {
      if(x /16 <10)
          printf("%d",x/16);
      else if(x/16 < 16)
          printf("%c",A+(x/16-10));
      if(x%16 < 10)
          printf("%d",x%16);
      else
          printf("%c",A+(x%16-10));

   }

}
int main(){

   //freopen("/home/plac/problem/input.txt","r",stdin);
   //freopen("/home/plac/problem/output.txt","w",stdout);
   int t; 
   scanf("%d",&t);
   getchar();
   while(t--)
   {
      gets(str);
      int k = strlen(str);
      int b = 2097152,c = 16384 , d= 128;
     // scanf("%d",&k); 
      if(k >= b)
      {
        print(k%d+d);
        print(k%c/d+d);
        print(k%b/c+d);
        print(k/b);
      }
      else if(k >= c)
      {
         print(k%d+d);
         print(k%c/d+d);
         print(k/c);
      }
      else if(k >= d)
      {
        print(k%d +d);
        print(k/d);
      }
      else print(k);
      
      for(int i = 0 ;i < k ;i ++)
          if(str[i] < 16)
              print(str[i]);
          else 
              print(str[i]);
      printf("\n");
      
   
   }
return 0 ;
}
bubuko.com,布布扣

ZOJ Problem Set - 3713,布布扣,bubuko.com

ZOJ Problem Set - 3713

原文:http://www.cnblogs.com/Alandre/p/3619520.html

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