2023杭电多校第二场1007-foreverlasting and fried-chicken

news2024/10/7 4:27:26

链接:Problem - 7293 (hdu.edu.cn)

思路:

        枚举度大于4 和 6 且 共同连接 4个以上点 的两个点, 其度分别记为a 和 b

        若a为上面的点,  那么答案为C(a-4, 2) * C(b, 4), 反之同理

         如果直接搜点会tle, 此时用bitset优化, 状态压缩, 时间复杂度为O(n^3 /32)

代码如下:

#include<iostream>
#include<bitset>

using namespace std;

typedef long long ll;

const int N = 1010, mod = 1e9+7;

int fact[N], infact[N];
bitset<N> g[N];

int qmi(int a, int k, int p) 
{
    int res = 1 % p;
    while(k)
    {
        if (k & 1) res = (ll)res * a % p;
        a = (ll)a * a % p;
        k >>= 1;
    }
    return res;
}

void init()
{
    fact[0] = infact[0] = 1;
    for(int i = 1; i < N; i++)
	{
        fact[i] = (ll)fact[i-1] * i % mod;
        infact[i] = (ll)infact[i-1] * qmi(i, mod-2, mod) % mod;
    }
}

int C(int a, int b)
{
    if(b > a) return 0;
    return (ll)fact[a] * infact[b] % mod * infact[a - b] % mod;
}

void solve()
{
	int n, m;
    cin >> n >> m;
    
    for(int i = 1; i <= n; i++) g[i].reset();
    for(int i = 1; i <= m; i++)
	{
        int a, b;
		cin >> a >> b;
        g[a].set(b), g[b].set(a);
    }
    
    int res = 0;
    for(int i = 1; i <= n; i++)
	{
        for(int j = i + 1 ; j <= n; j++)
		{
            auto tmp = g[i] & g[j]; //bitset<N>
            int cnt = tmp.count();
            if (tmp.count() >= 4)
            {
                int a = g[i].count(), b = g[j].count();
                if(g[i][j]) a--, b--;//如果点i到j有边的话, 就减去这条边
                if(a >= 6)
                    res = (res + (ll)C(cnt, 4) * C(a-4, 2)) % mod;
                    
                if(b >= 6)
                    res = (res + (ll)C(cnt, 4) * C(b-4, 2)) % mod;

            }
        }
    }
    cout << res << endl;
}

int main()
{
    cin.tie(0); cout.tie(0); ios::sync_with_stdio(0);
    
    int T;
    cin >> T;
    
    init();
    
    while(T--) solve();
    
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/778975.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

只需3步,使用Stable Diffusion无限生产AI数字人视频

效果演示 先看效果&#xff0c;感兴趣的可以继续读下去。 没有找到可以上传视频的地方&#xff0c;大家打开这个网盘链接观看&#xff1a;https://www.aliyundrive.com/s/CRBm5NL3xAE 基本方法 搞一张照片&#xff0c;搞一段语音&#xff0c;合成照片和语音&#xff0c;同…

APP抓包-资产获取+Frida反代理绕过和证书校验绕过

app抓包获取资产 1.打开模拟器&#xff0c;和电脑连接同一个wifi&#xff0c;让模拟器和电脑处于同一局域网&#xff0c;在模拟器配置代理。 burp开启监听 模拟器开启app&#xff0c;burp成功获取资产信息 有时候明明配置没问题&#xff0c;为什么抓不到app数据包呢&#xff1f…

Folx Pro 5 最好用的Mac磁力链接BT种子下载工具

除了迅雷&#xff0c;还有哪个支持磁力链接下载&#xff1f;Mac电脑如何下载磁力链接&#xff1f;经常有小伙伴问老宅。今天&#xff0c;老宅给大家推荐Folx Pro For Mac&#xff0c;Mac系统超好用的磁力下载工具。 Folx是一款功能强大且易于使用的Mac下载管理器&#xff0c;并…

ChatGPT开放自定义系统级别的指令,可设置偏好变成专属助理

OpenAI官方消息https://openai.com/blog/custom-instructions-for-chatgpt OpenAI为其大型语言模型接口ChatGPT引入了自定义指令&#xff0c;旨在为用户提供更加量身定制和个性化的体验&#xff0c;可以设置您的偏好&#xff0c;ChatGPT将在未来的所有对话中记住它们。 该功…

linux:cloudfare证书申请及应用到nginx

参考&#xff1a; 免费申请网站SSL证书 有效期15年 全站开启https_哔哩哔哩_bilibili 总结&#xff1a; 登陆www.cloudfare.com 注册账号 Add a Site 增加站点 站点设置完毕后Add record 记住这个Proxy status一定要勾选&#xff0c;这是cloudfare代理https请求转发到你的服务器…

Java开发基础系列(十):异常处理

&#x1f60a; 作者&#xff1a; 一恍过去 &#x1f496; 主页&#xff1a; https://blog.csdn.net/zhuocailing3390 &#x1f38a; 社区&#xff1a; Java技术栈交流 &#x1f389; 主题&#xff1a; Java开发基础系列(十):异常处理 ⏱️ 创作时间&#xff1a; 2023年07月…

深度学习——生成对抗网络GAN

基本概念 概述 GAN是一种深度学习模型&#xff0c;它是一种无监督学习算法&#xff0c;用于从随机噪声中生成逼真的数据&#xff0c;比如图像、音频、文本等。GAN的结构由两个神经网络组成&#xff1a;生成器&#xff08;Generator&#xff09;和判别器&#xff08;Discrimin…

谈谈面试大厂中碰到的问题

面试IT公司的小技巧 非常不建议在简历上造假&#xff0c;简历上能起到关键作用、有分量的部分&#xff0c;别人都是有办法去核实的&#xff0c;比如教育背景、关键性的证书、奖项等&#xff1b;核实不了的&#xff0c;又基本上也对结果产生不了太大影响&#xff0c;又何必去画…

USG6000v防火墙的基本使用:制定安全策略让不同安全区域的设备进行访问

目录 一、首先配置环境&#xff1a; 二、实验拓扑及说明 拓扑&#xff1a; PC1和PC2配置ip地址&#xff1a;​编辑​编辑 r4路由器配置ip&#xff1a; 进行防火墙的设置&#xff1a; 1、创建trust1区域和untrust1区域 2、制定防火墙的策略&#xff1a; 3、为防火墙增加可以…

【PostgreSQL内核学习(四)—— 查询规划】

查询规划 查询规划总体处理流程pg_plan_queries函数standard_planner函数subquery_planner函数inheritance_planner函数grouping_planner函数 总结 声明&#xff1a;本文的部分内容参考了他人的文章。在编写过程中&#xff0c;我们尊重他人的知识产权和学术成果&#xff0c;力求…

SpringBoot原理分析 | 任务:异步、邮件、定时

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; 任务 异步任务 Java异步指的是在程序执行过程中&#xff0c;某些任务可以在后台进行&#xff0c;而不会阻塞程序的执行。通常情况下&#xff0c;Java异步使用线程池来…

Apikit 自学日记:如何使用定时执行测试用例功能呢?

API自动化测试其实可以设置定时任务&#xff0c;实现项目在无人值守的情况下自动测试并且发送报告给相应的邮箱&#xff0c;监控项目监控情况。 这样一来&#xff0c;就能大大提高工作效率。 目前在 APIkit中这一部分主要功能有&#xff1a; 1.允许对测试任务进行分组&#xf…

Llama 2: Open Foundation and Fine-Tuned Chat Models

文章目录 TL;DRIntroduction背景本文方案 实现方式预训练预训练数据训练细节训练硬件支持预训练碳足迹 微调SFTSFT 训练细节 RLHF人类偏好数据收集奖励模型迭代式微调&#xff08;RLHF&#xff09;拒绝采样&#xff08;Rejection Sampling&#xff09;PPO多轮一致性的系统消息&…

GAMS---典型优化模型和算法介绍、GAMS安装和介绍、GAMS程序编写、GAMS程序调试、实际应用算例演示与经验分享

优化分析是很多领域中都要面临的一个重要问题&#xff0c;求解优化问题的一般做法是&#xff1a;建立模型、编写算法、求解计算。常见的问题类型有线性规划、非线性规划、混合整数规划、混合整数非线性规划、二次规划等&#xff0c;优化算法包括人工智能算法和内点法等数学类优…

S32K144 GPIO外设分析

1. S32K144 GPIO外设特性 下面的内容来自于S32K用户手册的翻译&#xff0c;或者网上关于S32K系列的一些pdf文件介绍。有些内容可能会出现理解不到位或者翻译错误方面&#xff0c;如果大家有疑问最好可以查阅用户手册。 GPIO和PORT的数量 从用户手册&#xff0c;对于PCR&#x…

python try/except/finally

稍微总结一下&#xff0c;否则总是忘。 x abc def fetcher(obj, index): return obj[index] fetcher(x, 4) 输出&#xff1a; File "test.py", line 6, in <module> fetcher(x, 4) File "test.py", line 4, in fetcher return obj[index] …

实验四 回溯法

实验四 回溯法 售货员问题 1.实验内容 1、理解回溯法的深度优先搜索策略&#xff0c;掌握用回溯法解题的算法框架 2、设计并实现旅行售货员问题问题&#xff0c;掌握回溯算法。 2.实验环境 Java 3.问题描述 旅行售货员问题&#xff1a;设有一个售货员从城市1出发&#…

docker-compose自建RustDesk远程控制服务器

github&#xff1a; rustdesk/rustdesk-server: RustDesk Server Program (github.com) 一、创建 docker-compose.yml 文件&#xff0c;复制以下 docker-compose 配置文件内容到文件 version: 3networks:rustdesk-net:external: falseservices:hbbs:container_name: hbbspor…

开源ThinkMusic搭建音乐网站,并实现公网连接

1、前言 在我们的日常生活中&#xff0c;音乐已经成为不可或缺的要素之一&#xff0c;听几首喜欢的音乐&#xff0c;能让原本糟糕的心情变得好起来。虽然现在使用电脑或移动电子设备听歌都很方便&#xff0c;但难免受到诸多会员或VIP限制&#xff0c;难免让我们回想起音乐网站…

DAY6,C++(将顺序栈,顺序循环队列定义成模板类);

1.将顺序栈定义成模板类&#xff1b;​​​​​​ 顺序栈模板代码--- #include <iostream>using namespace std;template<typename T> class Stack { private:T *data; //指向堆区空间int top; //记录栈顶位置public:Stack(); //无参构造Stack(T size); //有…