IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 2021蓝桥杯 直线(枚举,set去重) -> 正文阅读

[数据结构与算法]2021蓝桥杯 直线(枚举,set去重)

直线
在这里插入图片描述
两个点(x1,y1)(x2,y2)确定的直线方程可以化为
(y1-y2)x-(x1-x2)y+y1(x1-x2)-(y1-y2)x1=0
即Ax+By+C=0的规范式
这样的好处在于不用除法,避免了浮点数精度的问题。
枚举范围内的所有点,保证y1>y2(或者保证y1<y2),去掉x1=x2或者y1=y2的情况(最后直接在结果中加上)。

import java.util.*;


public class Main{
	public static int gcd2(int a,int b) {
		a=Math.abs(a);
		b=Math.abs(b);
		int min=a<b?a:b;
		int max=a>b?a:b;
		int r=max%min;
		while(r!=0) {
			max=min;
			min=r;
			r=max%min;
		}
		return min;
	}
	public static int gcd3(int a,int b,int c) {
		a=Math.abs(a);
		b=Math.abs(b);
		c=Math.abs(c);
		return gcd2(a,gcd2(b,c));
	}
	public static void main(String[] Args) {
		Scanner sc=new Scanner(System.in);
		Set<String> s=new HashSet<String>();
		int a,b,c,d;
		int m=20,n=21;
		for(int x1=0;x1<m;x1++) {
			for(int y1=0;y1<n;y1++) {
				//外面两层循环枚举第一个点
				for(int x2=0;x2<m;x2++) {
					for(int y2=0;y2<n;y2++) {
						//里面两层循环枚举第二个点
						//斜率为0和斜率不存在的情况单独加
						//y1>y2保证枚举的A的系数为正,就可以保证唯一
						if(x1==x2 || y1==y2 || y1<y2) {
							continue;
						}
						a=y1-y2;
						b=x1-x2;
						c=y1*(x1-x2)-(y1-y2)*x1;
						if(c==0) {
							d=gcd2(a,b);
							s.add(String.valueOf(a/d)+'-'+String.valueOf(b/d));
						}else {
							d=gcd3(a,b,c);
							s.add(String.valueOf(a/d)+'-'+String.valueOf(b/d)+'-'+String.valueOf(c/d));
						}
						
					}
					
				}
			}
		}
		System.out.println(s.size()+m+n);
		sc.close();
	}
}

在这里插入图片描述
答案 2430
枚举因子的时候到sqrt(n)结束,可以显著降低时间复杂度。

import java.util.*;


public class Main{
	public static long get(long item) {
		long ans=0;
		for(long i=1;i<=Math.sqrt(item);i++) {
		if(item%i==0) {
			if(i*i==item)
				ans++;
			else ans+=2;
		}
		}
		return ans;
	
	}
	public static void main(String[] Args) {
		Scanner sc=new Scanner(System.in);
		Set<Long> s=new HashSet<Long>();
		long x=2021041820210418L;
		long ans=0;
		for(long i=1;i<=Math.sqrt(x);i++) {
			if(x%i==0) {
				//分别统计i和x/i的分解个数
				if(i*i==x) {
					ans+=get(i);
				}else {
					ans+=get(i);
					ans+=get(x/i);
				}
			}
		}
		System.out.print(ans);
		sc.close();
	}
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-06 23:27:37  更:2022-04-06 23:30:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:28:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码