模拟题这种东西啊~就是自己读题,自己打,没有别的方法。。。贴份6000+b的code跑;

#include <bits/stdc++.h>
using namespace std;
//typedef long long LL; const int N=1e5+10;
char s[N]; //输入串 char tmp[N];//每次要处理的串;
char t1[N]; //要处理的前半
char t3[N];
char t2[N]; //后半; //答案串,和答案数量
char ans[55][N];
int res; char jian[N];
int cal(char *a, char *b)//a-b
{
int jie = 0;
int lena = strlen(a);
int lenb = strlen(b);
int i,j;
for(i = lenb-1, j = lena-1; i >= 0 || j >= 0; i--,j--)
{
if(i >= 0)
a[j] = a[j]-(b[i]+jie)+'0';
else
a[j] = a[j]-jie;
if(a[j] < '0')
{
a[j] += 10;
jie = 1;
}
else
jie = 0;
}
int k;
for(int i = 0; i < lena; i++)
{
if(a[i] != '0')
{
k = i;
break;
}
}
int h = 0;
for(int i = k; i < lena; i++)
a[h++] = a[i];
if(!h) a[h++]='0';
a[h] = '\0';
strcpy(jian,a);
} int main()
{
char one[5];
strcpy(one,"1");
int cas=1;
int T;
scanf("%d",&T);
while(T--)
{
scanf("%s",tmp);
res=0;
while(1)
{
int len=strlen(tmp);
if(len==1)
{
strcpy(ans[res++],tmp);
break;
}
if(len%2) //奇数
{
char mid;
int num1,num2,num3;
num1=num2=num3=0;
for(int i=0;i<len/2;i++)
t3[num3++]=tmp[i];
for(int i=len/2-1;i>=0;i--)
t1[num1++]=tmp[i];
mid=tmp[len/2];
for(int i=len/2+1;i<len;i++)
t2[num2++]=tmp[i];
t1[num1]='\0';
t2[num2]='\0';
t3[num3]='\0'; int temp=strcmp(t2,t1);
if(temp>0)
{
int zsq=0;
for(int i=num1-1;i>=0;i--)
ans[res][zsq++]=t1[i];
ans[res][zsq++]=mid;
for(int i=0;i<num1;i++)
ans[res][zsq++]=t1[i];
ans[res][zsq]='\0';
cal(tmp,ans[res]);
res++;
strcpy(tmp,jian);
}
else if(temp==0)
{
strcpy(ans[res],tmp);
res++;
break;
}
else
{
if(mid=='0')
{
cal(t3,one);
if(t3[0]=='0')
{
strcpy(ans[res++],"1");
strcpy(ans[res++],"99");
break;
}
int zsq=0;
int jian_len=strlen(jian);
for(int i=0;i<jian_len;i++)
ans[res][zsq++]=jian[i];
ans[res][zsq++]=mid;
for(int i=jian_len-1;i>=0;i--)
ans[res][zsq++]=jian[i];
ans[res][zsq]='\0';
cal(tmp,ans[res]);
strcpy(tmp,jian);
res++;
}
else
{
mid--;
int zsq=0;
for(int i=0;i<num3;i++)
ans[res][zsq++]=t3[i];
ans[res][zsq++]=mid;
for(int i=num3-1;i>=0;i--)
ans[res][zsq++]=t3[i];
ans[res][zsq]='\0';
cal(tmp,ans[res]);
strcpy(tmp,jian);
res++;
}
} }
else //偶数
{
int num1,num2,num3;
num1=num2=num3=0;
for(int i=0;i<len/2;i++)
t3[num3++]=tmp[i];
for(int i=len/2-1;i>=0;i--)
t1[num1++]=tmp[i];
for(int i=len/2;i<len;i++)
t2[num2++]=tmp[i];
t1[num1]='\0';
t2[num2]='\0';
t3[num3]='\0'; int temp=strcmp(t2,t1);
if(temp>0)
{
int zsq=0;
for(int i=num1-1;i>=0;i--)
ans[res][zsq++]=t1[i];
for(int i=0;i<num1;i++)
ans[res][zsq++]=t1[i];
ans[res][zsq]='\0';
cal(tmp,ans[res]);
strcpy(tmp,jian);
res++;
}
else if(temp==0)
{
strcpy(ans[res],tmp);
res++;
break;
}
else
{
cal(t3,one);
if(jian[0]=='0')
{
strcpy(ans[res++],"1");
strcpy(ans[res++],"9");
break;
}
int zsq=0;
int jian_len=strlen(jian);
for(int i=0;i<jian_len;i++)
ans[res][zsq++]=jian[i];
for(int i=jian_len-1;i>=0;i--)
ans[res][zsq++]=jian[i];
ans[res][zsq]='\0';
cal(tmp,ans[res]);
strcpy(tmp,jian);
res++;
}
}
}
printf("Case #%d:\n",cas++);
printf("%d\n",res);
for(int i=0;i<res;++i)
printf("%s\n",ans[i]);
}
return 0;
}

HDU5920【模拟】的更多相关文章

  1. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  2. 故障重现, JAVA进程内存不够时突然挂掉模拟

    背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...

  3. Python 爬虫模拟登陆知乎

    在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...

  4. HTML 事件(四) 模拟事件操作

    本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4.  ...

  5. 模拟AngularJS之依赖注入

    一.概述 AngularJS有一经典之处就是依赖注入,对于什么是依赖注入,熟悉spring的同学应该都非常了解了,但,对于前端而言,还是比较新颖的. 依赖注入,简而言之,就是解除硬编码,达到解偶的目的 ...

  6. webapp应用--模拟电子书翻页效果

    前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...

  7. javascript动画系列第一篇——模拟拖拽

    × 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...

  8. C++ 事件驱动型银行排队模拟

    最近重拾之前半途而废的C++,恰好看到了<C++ 实现银行排队服务模拟>,但是没有实验楼的会员,看不到具体的实现,正好用来作为练习. 模拟的是银行的排队叫号系统,所有顾客以先来后到的顺序在 ...

  9. MSYS2——Windows平台下模拟linux环境的搭建

    最近从MSYS1.0迁移到了MSYS2.0,简单讲,MSYS2.0功能更强大,其环境模拟更加符合linux.虽然本身来自cygwin,但其集成了pacman软件管理工具,很有linux范,并且可以直接 ...

随机推荐

  1. Python 007- python的各种函数

    1.chr().unichr()和ord() chr()函数用一个范围在range(256)内的(就是0-255)整数作参数,返回一个对应的字符. unichr()跟它一样,只不过返回的是Unicod ...

  2. Net Core环境开发与调试

    NET Core 包括.NET Core Runtime 和 .NET Core SDK: .NET Core = 应用运行依赖的 .NET Core Runtime .NET Core SDK = ...

  3. Local Response Normalization 60 million parameters and 500,000 neurons

    CNN是工具,在图像识别中是发现图像中待识别对象的特征的工具,是剔除对识别结果无用信息的工具. ImageNet Classification with Deep Convolutional Neur ...

  4. BitMapFactory.decodeFile 总是返回NULL的原因之一

    之前碰到过,顺便记录下来,如果出现这种情况,首先看看是否有对这个文件的读权限.

  5. 最简单的Windows程序

    准备研究一下vmp 保护,从一个最简单的Windows程序入手似乎是个不错的想法. 如何才最简单呢,仅仅有一个MessageBox 调用好了. 弹出消息.退出,哦也,够简单吧. 祭出法器VC2010. ...

  6. UIView封装动画--iOS 利用系统提供方法来做弹性运动

    iOS 利用系统提供方法来做弹性运动 /*创建弹性动画 damping:阻尼,范围0-1,阻尼越接近于0,弹性效果越明显 velocity:弹性复位的速度 */ [UIView animateWith ...

  7. poj3461 Oulipo —— KMP

    题目链接:http://poj.org/problem?id=3461 代码如下: #include<cstdio>//poj 3461 kmp #include<cstring&g ...

  8. 动态负载均衡(Nginx+Consul+UpSync)环境搭建

    首先 安装好 Consul upsync 然后: 1.配置安装Nginx 需要做配置,包括分组之类的,创建目录,有些插件是需要存放在这些目录的 groupadd nginx useradd -g ng ...

  9. 使用IIS建立主机到虚拟机的端口转发

    主机是笔记本电脑,通过一个TPLINK智能扩展卡,作为服务器供给手机APP当作服务器. 但真正的Web服务,在主机的VMWare Workstation虚拟机80端口. 那么主机和手机形成的网络为19 ...

  10. linuxshell,闲散命令记录

    1. 移动光标到 0:0 位置 printf "\033[0;0H" 2. 清屏 printf "\033[2J" 3. awk接收 外部变量 awk -v v ...