题目链接:https://www.luogu.org/problemnew/show/P1351

做了些提高组的题,不得不说虽然NOIP考察的知识点虽然基本上都学过,但是做起题来还是需要动脑子的。

题目质量很高吧,觉得出的很有水平 (除了2017 d1t1

70分:

三层枚举强制到距离为2

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 2 * 1e6 + 10;
const int mod = 10007;
struct edge{
long long from, to, next, len;
}e[maxn<<2];
long long head[maxn], cnt;
long long n, val[maxn], ans, maxx;
void add(long long u, long long v)
{
e[++cnt].from = u;
e[cnt].next = head[u];
e[cnt].to = v;
head[u] = cnt;
}
int main()
{
memset(head, -1, sizeof(head));
scanf("%lld",&n);
for(long long i = 1; i < n; i++)
{
long long u, v;
scanf("%lld%lld",&u,&v);
add(u,v);
add(v,u);
}
for(long long i = 1; i <= n; i++)
scanf("%lld",&val[i]); /*for(long long i = 1; i <= cnt; i++)
{
cout<<i<<endl;
cout<<e[i].from<<" "<<e[i].to<<" "<<e[i].next<<endl;
}
for(long long i = 1; i <= n; i++) cout<<head[i]<<" ";cout<<"qwq"<<endl;*/
for(long long i = 1; i <= n; i++)
{
for(long long j = head[i]; j != -1; j = e[j].next)
{
for(long long k = head[e[j].to]; k != -1; k = e[k].next)
{
if(e[j].from != e[k].to)
{
//cout<<e[j].from<<" "<<e[k].to<<endl;
if(maxx < val[e[j].from] * val[e[k].to])
maxx = val[e[j].from] * val[e[k].to];
ans += val[e[j].from] * val[e[k].to] % mod;
}
}
}
}
cout<<maxx<<" "<<ans%mod;
}

100分:

每次枚举中间节点的所有儿子,再用完全平方公式倒退回去所有的2WiWj

这样做的复杂度为线性,如果强行组合所有方案是O(n^2)的

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 2 * 1e6 + 10;
const int mod = 10007;
struct edge{
long long from, to, next, len;
}e[maxn<<2];
long long head[maxn], cnt;
long long n, val[maxn], ans, maxx, totsq, totsum, fir, sec;
void add(long long u, long long v)
{
e[++cnt].from = u;
e[cnt].next = head[u];
e[cnt].to = v;
head[u] = cnt;
}
int main()
{
memset(head, -1, sizeof(head));
scanf("%lld",&n);
for(long long i = 1; i < n; i++)
{
long long u, v;
scanf("%lld%lld",&u,&v);
add(u,v);
add(v,u);
}
for(long long i = 1; i <= n; i++)
scanf("%lld",&val[i]); for(long long i = 1; i <= n; i++)
{
fir = 0, sec = 0;
long long son1 = 0, son2 = 0;
for(long long j = head[i]; j != -1; j = e[j].next)
{
if(val[e[j].to] > fir)
{
sec = fir;
fir = val[e[j].to];
}
else if(val[e[j].to] > sec)
{
sec = val[e[j].to];
}
son1 = (son1 + val[e[j].to]) % mod;
son2 = (son2 + val[e[j].to] * val[e[j].to]) % mod;
}
if(sec == 0) continue;
if(maxx < fir * sec)
maxx = fir * sec; son1 = son1 * son1 % mod;
ans = (ans + son1 - son2 + 10007)%10007;
}
printf("%lld %lld",maxx, ans);
return 0;
}

最新文章

  1. Eclipse中修改Web项目的URL访问路径
  2. javascript获取iframe框架中页面document对象,获取子页面里面的内容,iframe获取父页面的元素,
  3. How to configure Veritas NetBackup (tm) to write Unified and Legacy log files to a different directory
  4. 【Linux】——ctags
  5. Android Service Intent must be explicit的解决方法
  6. [HDOJ5573]Binary Tree(找规律,贪心)
  7. Delphi和JAVA用UTF-8编码进行Socket通信例子
  8. 113. Path Sum II
  9. Linq 与UnitOfWork
  10. Android网络传输中必用的两个加密算法:MD5 和 RSA
  11. Java没有源代码的同步集合~
  12. angular-ui-bootstrap插件API - Pager
  13. Docker技术知识点总结
  14. json server服务器
  15. php插入日志到数据库,对象转json
  16. replay的意义
  17. mac 上使用 zip 版的mysql
  18. BSS, DATA, TEXT, HEAP, STACK
  19. ui设计用什么软件
  20. scp的两种方式

热门文章

  1. springboot集成websocket点对点推送、广播推送
  2. Excel的Sheet页复制
  3. CSS之after与before的content 和 attr 配合使用
  4. Web前端面试指导(十一):样式导入有哪些方式?
  5. &lt;Android 应用 之路&gt; 百度地图API使用(2)
  6. vs生成的exe程序和相关dll打包
  7. 基于Vue的WebApp项目开发(二)
  8. scrum心得和团队作业
  9. android webview 播放 video经验总结
  10. SQL Server -&gt;&gt; 校检函数CHECKSUM、CHECKSUM_AGG、BINARY_CHECKSUM和HASHBYTES