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亚洲区沈阳站-重现赛的更多相关文章

  1. HDU 6227.Rabbits-规律 (2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学))

    Rabbits Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total S ...

  2. HDU 6225.Little Boxes-大数加法 (2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学))

    整理代码... Little Boxes Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/O ...

  3. 2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学)

    Little Boxes Problem Description Little boxes on the hillside.Little boxes made of ticky-tacky.Littl ...

  4. 2016ACM/ICPC亚洲区沈阳站-重现赛赛题

    今天做的沈阳站重现赛,自己还是太水,只做出两道签到题,另外两道看懂题意了,但是也没能做出来. 1. Thickest Burger Time Limit: 2000/1000 MS (Java/Oth ...

  5. 2016ACM/ICPC亚洲区沈阳站-重现赛

    C.Recursive sequence 求ans(x),ans(1)=a,ans(2)=b,ans(n)=ans(n-2)*2+ans(n-1)+n^4 如果直接就去解...很难,毕竟不是那种可以直 ...

  6. hdu 5510 Bazinga (kmp+dfs剪枝) 2015ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学)

    废话: 这道题很是花了我一番功夫.首先,我不会kmp算法,还专门学了一下这个算法.其次,即使会用kmp,但是如果暴力枚举的话,还是毫无疑问会爆掉.因此在dfs的基础上加上两次剪枝解决了这道题. 题意: ...

  7. 2015ACM/ICPC亚洲区沈阳站重现赛-HDU5512-Pagodas-gcd

    n pagodas were standing erect in Hong Jue Si between the Niushou Mountain and the Yuntai Mountain, l ...

  8. 2015ACM/ICPC亚洲区沈阳站-重现赛 M - Meeting (特殊建边,最短路)

    题意:有\(n\)个点,\(m\)个集合,集合\(E_i\)中的点都与集合中的其它点有一条边权为\(t_i\)的边,现在问第\(1\)个点和第\(n\)个点到某个点的路径最短,输出最短路径和目标点,如 ...

  9. 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\) ...

随机推荐

  1. width,height为多少px时,A4纸打印时刚好一页?

    计算方式一般的分辨率为XX像素/英寸,其中一英寸为25.4毫米.所以一毫米的像素数就为XX/25.4.现在的工作就是求XX的值了,把XX的值求出来以后,直接用XX/25.4 * 210就得到A4纸的像 ...

  2. Bash 笔记

    获取当前工作目录 basepath=$(cd `dirname $0`; pwd) 源文 : https://sexywp.com/bash-how-to-get-the-basepath-of-cu ...

  3. 分布式监控系统Zabbix-添加windows监控主机

    大多数情况下,线上服务器都是linux系统,但是偶尔也会有些windows机器.下面简单介绍下zabbix添加windows监控机的操作:1)下载windows的zabbix_agent下载地址:ht ...

  4. 代码规范(RL-TOC)用更合理的方式写 JavaScript

    代码可以改变世界 不规范代码可以毁掉世界 只有先学会写规范的代码,才可以走的更远 编程语言之间有很多编程规范都是通用: 命名 不要用语言不明的缩写,不用担心名字过长,名字一定要让别人知道确切的意思; ...

  5. BugPhobia开发篇章:Beta阶段第VIII次Scrum Meeting

    0x01 :Scrum Meeting基本摘要 Beta阶段第八次Scrum Meeting 敏捷开发起始时间 2015/12/22 00:00 A.M. 敏捷开发终止时间 2015/12/22 23 ...

  6. 《Linux内核设计与实现》读书笔记三

    Chapter 18 调 试 18.1 准备开始 1.准备工作: 一个bug 一个藏匿bug的内核版本 相关内核代码的知识和运气 2.执行foo就会让程序立即产生核心信息转储(dump core). ...

  7. 同步手绘板——android端下笔后颜色变化

    实现效果 : 在设计之初我们以为是改变笔线条的粗细来实现类似效果,后来通过找其他相关软件比对发现是不改变线条的粗细,通过改变透明度实现下笔后颜色的渐变,虽然已实现,但渐变效果很一般,不流畅,算法还待优 ...

  8. win10装MySQL5.7

    越来越发现装MySQL很费劲啊,装了N次,都很懵逼,找对的解决方案很重要. Mysql5.7下载地址:http://xiazai.zol.com.cn/detail/4/33431.shtml 安装步 ...

  9. jiedui

    源代码:https://github.com/hanzhaoyan/jieduizuoye/tree/master 功能要求: 该程序用图形界面实现下面功能:用计算机产生一个100以内的随机数,游戏者 ...

  10. Linux: HowTo See Directory Tree Structure

    https://www.cyberciti.biz/faq/linux-show-directory-structure-command-line/ Linux: HowTo See Director ...