2017ACM/ICPC亚洲区沈阳站-重现赛
HDU 6222 Heron and His Triangle
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6222
思路: 打表找规律+大数运算
首先我们可以打个表暴力跑出前几个满足题意的T
打表代码:
#include<bits/stdc++.h>
using namespace std;
bool fun(double n) {
if(abs(round(n) - n) < 0.000000000000001)
return ;
return ;
} int main()
{
for(int i = ;i <= ;i ++){
double num = (i+)*sqrt(*(i-)*(i+))/;
if(fun(num))
cout<<i+<<endl;
}
}
打出表后会得到: 4,14,52,194,724等数据。。。经过推导我们会得到他们之间的公式: a[i] = a[i-1]*4-a[i-2],然后我们用大数模板去跑这串公式就好了
实现代码:
#include<bits/stdc++.h>
using namespace std;
/*bool fun(double n) {
if(abs(round(n) - n) < 0.000000000000001)
return 1;
return 0;
} int main()
{
for(int i = 2;i <= 10000000;i ++){
double num = (i+1)*sqrt(3*(i-1)*(i+3))/4;
if(fun(num))
cout<<i+1<<endl;
}
}*/
string Mult(string s,int x) //大数乘以整形数
{
reverse(s.begin(),s.end());
int cmp=;
for(int i=;i<s.size();i++)
{
cmp=(s[i]-'')*x+cmp;
s[i]=(cmp%+'');
cmp/=;
}
while(cmp)
{
s+=(cmp%+'');
cmp/=;
}
reverse(s.begin(),s.end());
return s;
} string sub(string a,string b)
{
string c;
bool ok=;
int len1=a.length();
int len2=b.length();
int len=max(len1,len2);
for(int i=len1;i<len;i++)
a=""+a;
for(int i=len2;i<len;i++)
b=""+b;
if(a<b)
{
string temp=a;
a=b;
b=temp;
ok=;
}
for(int i=len-;i>=;i--)
{
if(a[i]<b[i])
{
a[i-]-=;
a[i]+=;
}
char temp=a[i]-b[i]+'';
c=temp+c;
}
int pos=;
while(c[pos]=='' && pos<len) pos++;
if(pos==len) return "";
if(ok) return "-"+c.substr(pos);
return c.substr(pos);
}
string s1[]; int main()
{
int t;
cin>>t;
string s;
s1[] = "";s1[] = "";
for(int i = ;i <= ;i ++)
s1[i] = sub(Mult(s1[i-],),s1[i-]);
while(t--){
cin>>s;
for(int i = ;i <= ;i ++)
if(s1[i].size() > s.size()||(s1[i].size()==s.size()&&s1[i]>=s)){
cout<<s1[i]<<endl;
break;
}
}
return ;
}
HDU 6223 Infinite Fraction Path
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6223
思路:bfs + 剪枝
算比较容易的bfs,一直没怎么写bfs,差点写自闭了。。。。调了半天才过。
实现代码:
#include<bits/stdc++.h>
using namespace std;
const int M = 4e5+;
#define ll long long
int vis[M]; //判断当前点是否被访问过了
int n,a[M],top;
int cnt[M]; //储存当前层被标记点的下标
int mx[M]; //每一层的最大值
struct node{
long long id;
int val,step;
};
//优先排步数小的,步数相等优先值大的
bool operator < (node a,node b){
if(a.step == b.step) return a.val < b.val;
return a.step > b.step;
}
priority_queue<node> q;
void bfs(){
int last = -;
while(!q.empty()){
node now = q.top();
q.pop();
if(now.step != last) { //已经步入下一层了清空上一层的标记
last = now.step;
while(top) vis[cnt[--top]] = ;
}
//限制条件剪枝
if(now.step == n) continue;
if(vis[now.id]) continue; //当前点被访问过了,跳过
if(mx[now.step] > now.val) continue; //当前点小于这一层的最大值,跳过
//维护标记
cnt[top++] = now.id;
vis[now.id] = ; mx[now.step] = now.val;
//将下一个点扔进队列中
node next;
next.id = (now.id*now.id+)%n;;
next.val = a[next.id];
next.step = now.step+;
q.push(next);
}
for(int i = ;i < n;i ++) printf("%d",mx[i]);
for(int i = ;i <= n;i ++) mx[i] = ;
printf("\n");
}
char s[M];
int main()
{ int maxx,t;
scanf("%d",&t);
int t1 = t;
while(t--){
top = ;
scanf("%d",&n);
maxx = ;
scanf("%s",s);
for(int i = ;i < n;i ++){
a[i] = s[i]-'';
maxx = max(maxx,a[i]);
}
mx[] = maxx;
for(int i = ;i < n;i ++)
if(a[i] == maxx){
node now; now.id = i;now.val = a[i],now.step = ;
q.push(now);
}
printf("Case #%d: ",t1-t);
bfs();
}
return ;
}
HDU 6225 Little Boxes
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6225
大数加法
签到题
实现代码:
#include<bits/stdc++.h>
using namespace std; string sum(string s1,string s2)
{
if(s1.length()<s2.length())
{
string temp=s1;
s1=s2;
s2=temp;
}
int i,j;
for(i=s1.length()-,j=s2.length()-;i>=;i--,j--)
{
s1[i]=char(s1[i]+(j>=?s2[j]-'':));
if(s1[i]-''>=)
{
s1[i]=char((s1[i]-'')%+'');
if(i) s1[i-]++;
else s1=''+s1;
}
}
return s1;
}
int main()
{
int n;
string x;
cin>>n;
for(int i = ;i <= n;i ++){
string ans = "";
for(int j = ;j <= ;j ++){
cin>>x;
ans = sum(ans,x);
}
cout<<ans<<endl;
}
return ;
}
HDU 6227 Rabbits
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6227
思路: 求兔子最多跳的次数,排个序,两种情况取最大的:
第一种: 第二小的和最大的之间距离之差减去中间已经有位置的值
第二种: 倒着跳,第二大的和最小的距离之差减去中间已经有位置的值
签到题
实现代码:
#include<bits/stdc++.h>
using namespace std;
int a[];
int main()
{
int t,n,x;
scanf("%d",&t);
while(t--){
scanf("%d",&n);
for(int i = ;i <= n;i ++)
scanf("%d",&a[i]);
sort(a+,a++n);
int ans = max(a[n]-a[]-n+,a[n-]-a[]-n+);
printf("%d\n",ans);
}
return ;
}
HDU 6228 Tree
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6228
思路:
要求公共子集最大,我们肯定是优先选择距离大的两点染成相同的颜色(因为要留位置给其他颜色),要达到公共边最多,那么我们可以先对边进行分析,如果一条边左边结点的子树大于k,右边结点的子树也大于k那么这条边可以成为公共子集的一条因为我们是要求最大的,根据最优策略,肯定要将他加进最大公共子集中,找到这种边+1就好了。
实现代码;
#include<bits/stdc++.h>
using namespace std;
const int M = 1e5 + ;
vector<int>g[M];
int ans,n,k,siz[M];
void dfs(int u,int fa){
siz[u] = ;
for(int i = ;i < g[u].size();i ++){
int v = g[u][i];
if(v == fa) continue;
dfs(v,u);
siz[u] += siz[v];
if(siz[v] >= k&&(n-siz[v])>=k) ans++;
}
} int main()
{
int t,x,y;
scanf("%d",&t);
while(t--){
memset(siz,,sizeof(siz));
scanf("%d%d",&n,&k);
for(int i = ;i <= n;i ++)
g[i].clear();
for(int i = ;i < n;i ++){
scanf("%d%d",&x,&y);
g[x].push_back(y);
g[y].push_back(x);
}
ans = ;
dfs(,-);
printf("%d\n",ans);
}
}
2017ACM/ICPC亚洲区沈阳站-重现赛的更多相关文章
- HDU 6227.Rabbits-规律 (2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学))
Rabbits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total S ...
- HDU 6225.Little Boxes-大数加法 (2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学))
整理代码... Little Boxes Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/O ...
- 2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学)
Little Boxes Problem Description Little boxes on the hillside.Little boxes made of ticky-tacky.Littl ...
- 2016ACM/ICPC亚洲区沈阳站-重现赛赛题
今天做的沈阳站重现赛,自己还是太水,只做出两道签到题,另外两道看懂题意了,但是也没能做出来. 1. Thickest Burger Time Limit: 2000/1000 MS (Java/Oth ...
- 2016ACM/ICPC亚洲区沈阳站-重现赛
C.Recursive sequence 求ans(x),ans(1)=a,ans(2)=b,ans(n)=ans(n-2)*2+ans(n-1)+n^4 如果直接就去解...很难,毕竟不是那种可以直 ...
- hdu 5510 Bazinga (kmp+dfs剪枝) 2015ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学)
废话: 这道题很是花了我一番功夫.首先,我不会kmp算法,还专门学了一下这个算法.其次,即使会用kmp,但是如果暴力枚举的话,还是毫无疑问会爆掉.因此在dfs的基础上加上两次剪枝解决了这道题. 题意: ...
- 2015ACM/ICPC亚洲区沈阳站重现赛-HDU5512-Pagodas-gcd
n pagodas were standing erect in Hong Jue Si between the Niushou Mountain and the Yuntai Mountain, l ...
- 2015ACM/ICPC亚洲区沈阳站-重现赛 M - Meeting (特殊建边,最短路)
题意:有\(n\)个点,\(m\)个集合,集合\(E_i\)中的点都与集合中的其它点有一条边权为\(t_i\)的边,现在问第\(1\)个点和第\(n\)个点到某个点的路径最短,输出最短路径和目标点,如 ...
- 2015ACM/ICPC亚洲区沈阳站-重现赛 B - Bazinga (KMP)
题意:给你\(n\)个字符串,\(s_1,s_2,...,s_n\),对于\(i(1\le i\le n)\),找到最大的\(i\),并且满足\(s_j(1\le j<i)\)不是\(s_i\) ...
随机推荐
- 11-51单片机ESP8266学习-AT指令(ESP8266作为TCP客户端,连接TCP服务器,用串口调试助手和手机TCP调试助手测试)
写完题目刚想起来一件事情,如果手机作为客户端(不连接路由器的情况下),手机连接模块的无线会分配一个IP地址,,,这个IP地址事先我也不知道....我先看看AT指令里面有没有一个指令可以打印一下连接自己 ...
- 初识Identity(二)
本文参考了[ASP.NET Identity系列教程(一)]ASP.NET Identity入门 一.Identity使用前准备项目 本文创建了一个名称为Users的项目.在创建过程中选择了“Empt ...
- 开源的mqtt服务器
看介绍挺强大,开源,可运行在Linux和Windows,文档中有相关测试工具,及客户端介绍. 希望有机会应用.http://www.emqtt.com/
- 浅谈CDQ分治与偏序问题
初识CDQ分治 CDQ分治是一个好东西,一直听着dalao们说所以就去学了下. CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. ...
- Opencv 2.4.10 +VS2010 项目配置
资料来源:http://blog.csdn.net/scottly1/article/details/40978625
- 如何看待P2P领域的羊毛党?
本文来自网易云社区 不利:不利的影响应该是显而易见的,前面的题主也有解释过.总结来说,不利的影响主要是两点: a. 对平台毛利和资金的损害.一般来说,优惠活动本是一个用户只能享用一次,但如果注册多个账 ...
- Python从菜鸟到高手(1):初识Python
1 Python简介 1.1 什么是Python Python是一种面向对象的解释型计算机程序设计语言,由荷兰人吉多·范罗苏姆(Guido van Rossum)于1989年发明,第一个公开发行版 ...
- ABP module-zero +AdminLTE+Bootstrap Table+jQuery权限管理系统第十五节--缓存小结与ABP框架项目中 Redis Cache的实现
返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 缓存 为什么要用缓存 为什么要用缓存呢,说缓存之前先说使用缓存的优点. 减少寄宿服务器的往返调用(round-tr ...
- ExtJS初探:在项目中使用ExtJS
注意:本文写作时间是 2013 年,所讲的 ExtJS 如今早已过时,请勿学习! -------------------------------- 今天ExtJS官网发布了ExtJS最新正式版4.2. ...
- 更换Ubuntu源为国内源的操作记录
我们都知道,Ubuntu的官方源对于国内用户来说是比较慢的,可以将它的源换成国内的源(比如阿里源),这样用起来就很快了.下面记录下更换操作: 首先了解下/etc/apt/sources.list文件 ...