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\) ...
随机推荐
- ASP.NET MVC和ASP.NET Core MVC中获取当前URL/Controller/Action (转载)
ASP.NET MVC 一.获取URL(ASP.NET通用): [1]获取完整url(协议名+域名+虚拟目录名+文件名+参数) string url=Request.Url.ToString(); [ ...
- ASP.NET Web API上实现 Web Socket - 转
1. 什么是Web Socket Web Socket是Html5中引入的通信机制,它为浏览器与后台服务器之间提供了基于TCP的全双工的通信通道.用以替代以往的LongPooling等comet st ...
- el标签将时间戳转换为特定格式以及将数值保留特定小数
jsp中/el表达式中将后台传来的时间戳格式化为年月日时分秒 1.引入相关标签库 <%@taglib prefix="c" uri="http://java.sun ...
- 【JVM.6】虚拟机类加载机制
一.概述 虚拟机类加载机制:虚拟机把描述类的数据从Class文件中加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型. 与那些在编译时需要进行连接工作的语言不同 ...
- CentOS搭建NAT和DHCP服务,实现共享上网
什么是NAT? NAT(Network address translation)即网络地址转换,作为一种过渡解决手段,可以用来减少对全球合法IP地址的需求.简单的说,NAT就是在内部专用网络中使用内部 ...
- PHP实现验证码制作
captcha.php(PHP产生验证码并储存Session): <?php //开启Session session_start(); //绘制底图 $image = imagecreatetr ...
- Linux Namespace : PID
PID namespace 用来隔离进程的 PID 空间,使得不同 PID namespace 里的进程 PID 可以重复且互不影响.PID namesapce 对容器类应用特别重要, 可以实现容器内 ...
- 分布式监控系统Zabbix--完整安装记录 -添加apache监控
前面介绍了zabbix3.0.3环境及相关监控项的添加,下面介绍下针对apache的监控配置:1)在apache配置文件中打开server-status状态访问功能(自带的) [root@IDC-Ad ...
- Linux系统本地yum源环境配置记录
由于IDC的一些服务器没有外网,不能对外访问.所以打算部署一套内网的yum源环境,以供内网服务器使用.以下简单记录下操作过程: 1)下载centos6.9和centos7.3的镜像,并挂载 [root ...
- SqlDataAdapter简单介绍 (转)
From: http://blog.sobnb.com/u/92/5532.html 一.特点介绍 1.表示用于填充 DataSet 和更新 SQL Server 数据库的一组数据命令和一个数据库连 ...