基本数学题一道,看错位数,当成大数减做了,而且还把方向看反了。所求为最接近l的值。

 #include <cstdio>

 int f(__int64 x) {
int i, sum; i = sum = ;
while (x) {
if (i & )
sum -= x%;
else
sum += x%;
++i;
x/=;
}
return sum;
} int main() {
__int64 l, r, x;
bool flg;
int t; scanf("%d", &t);
while (t--) {
scanf("%I64d%I64d", &l, &r);
for (x=l;;++x)
if (x% == )
break;
flg = false;
while (x <= r) {
if (f(x) != ) {
flg = true;
break;
}
x += ;
}
if (flg)
printf("%I64d\n", x);
else
printf("-1\n");
} return ;
}

好歹写出来大数减了,贴上吧。

 #include <cstdio>
#include <cstring>
#include <iostream>
#include <string>
using namespace std; string SRCB="";
bool stop; int check(string s) {
int sum=;
int len = s.length();
int i = , j; while (s[i]) {
--len;
j = s[i] - '';
if (len & )
sum -= j;
else
sum += j;
++i;
}
return sum;
} string Minus(string a,string b) {
string c="",ans="",t;
int flag=, k=; if(a.length()<b.length()||(a.length()==b.length()&& a.compare(b)<)) {
t=a;
a=b;
b=t;
stop=true;
return "";
}
int i=a.length()-,j=b.length()-;
while(i>=&&j>=) {
if(a[i]+flag>b[j]) { c+=a[i]+flag-b[j]+'';
flag=;
} else if (a[i]+flag==b[j]) {
c+='';
flag=;
} else {
c+=(a[i]-'')+flag+-(b[j]-'')+'';
flag=-;
}
i--;
j--;
k++;
}
while(i>=) {
if(a[i]+flag<'') {
c+=a[i]+flag+;
flag=-;
} else {
c+=a[i]+flag;
flag=;
}
i--,k++;
}
int len=k-;
while(c[len]=='' && len>)
len--;
for(j=;j<=len;j++)
ans+=c[j];
char tt;
for(i=,j=ans.length()-;i<j;i++,j--) {
tt = ans[i];
ans[i] = ans[j];
ans[j]=tt;
}
return ans;
} int main() {
int t, tmp, ttmp;
string l, r, ans;
bool flag;
char x[];
//FILE *fout = fopen("data2", "w"); scanf("%d", &t);
while (t--) {
cin >>l>>r;
flag = stop = false;
tmp = check(r);
ttmp = tmp%;
if (ttmp < )
ttmp += ;
if (ttmp > ) {
x[] = ttmp-+'';
x[] = '\0';
ans = Minus(r, string(x));
} else if (ttmp < ) {
x[] = +ttmp+'';
x[] = '\0';
ans = Minus(r, string(x));
} else {
ans = r;
}
if (stop) {
printf("-1\n");
continue;
}
while (l.length()<ans.length() || (l.length()==ans.length()&&l.compare(ans)<=)) {
if (check(ans) != ) {
flag = true;
break;
}
//cout <<ans<<endl;
ans = Minus(ans, SRCB);
if (stop)
break;
}
if (flag) {
cout <<ans<<endl;
//fprintf(fout, "%s\n", ans.data());
} else {
printf("-1\n");
//fprintf(fout, "-1\n");
}
//fprintf(fout, "%d\n", ans);
}
//fclose(fout);
return ;
}

【HDOJ】4956 Poor Hanamichi的更多相关文章

  1. hdu 4956 Poor Hanamichi BestCoder Round #5(数学题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4956 Poor Hanamichi Time Limit: 2000/1000 MS (Java/Ot ...

  2. [BestCoder Round #5] hdu 4956 Poor Hanamichi (数学题)

    Poor Hanamichi Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  3. 【HDOJ】4729 An Easy Problem for Elfness

    其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...

  4. 【HDOJ】【3506】Monkey Party

    DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...

  5. 【HDOJ】【3516】Tree Construction

    DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...

  6. 【HDOJ】【3480】Division

    DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...

  7. 【HDOJ】【2829】Lawrence

    DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...

  8. 【HDOJ】【3415】Max Sum of Max-K-sub-sequence

    DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...

  9. 【HDOJ】【3530】Subsequence

    DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...

随机推荐

  1. javascript touch事件

    touchstart : 當手指觸摸屏幕時觸發:即使已經有一個手指放在了屏幕上也會觸發. touchmove : 當手指在屏幕上滑動時連續的觸發,在這個事件發生期間,商用preventDefault( ...

  2. <<java 并发编程>>第七章:取消和关闭

    Java没有提供任何机制来安全地终止线程,虽然Thread.stop和suspend等方法提供了这样的机制,但是存在严重的缺陷,应该避免使用这些方法.但是Java提供了中断Interruption机制 ...

  3. const常量折叠

    首先来看一个例子: int main(int argc, char* argv[]) { ; int *j = (int *) &i; *j=; cout<<&i<& ...

  4. Android系统移植与驱动开发——第六章——使用实例来理解Linux驱动开发及心得

    Linux驱动的工作方式就是交互.例如向Linux打印机驱动发送一个打印命令,可以直接使用C语言函数open打开设备文件,在使用C语言函数ioctl向该驱动的设备文件发送打印命令.编写Linux驱动最 ...

  5. JPA事务回滚配置

    <!-- 配置事务管理器 --> <bean id="transactionManager" class="org.springframework.or ...

  6. 动态代理 Proxy InvocationHandler

      前奏 代理模式 代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等. 代理类与委托类之间通常 ...

  7. mysql sql语句大全(2)

    1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份 ...

  8. WebService简单使用

    1.创建Webservice服务应用程序 方式一:将VS2010采用的默认框架,改为使用框架.NET Framework2.0\3.0\3.5,这时新建"项目"or新建" ...

  9. 一个类实现多个接口的demo

    //A接口 interface A{ public int getA(); } //B接口 interface B{ public int getB(); } //实现了某个接口必须实现其全部的方法 ...

  10. asp.net微信开发第五篇----用户分组管理

    上一篇已讲解到新建用户分组,移动用户到分组的功能,这一章主要讲解修改分组名称和删除分组 开发者可以使用接口,对公众平台的分组进行查询.创建.修改.删除等操作,也可以使用接口在需要时移动用户到某个分组. ...