[蓝桥杯]真题讲解:数三角(枚举+STL)

[蓝桥杯]真题讲解:数三角(枚举+STL)

一、视频讲解

[蓝桥杯]真题讲解:数三角(枚举+STL)

二、正解代码

1、C++

cpp 复制代码
#include<bits/stdc++.h>
#define int long long 
using namespace std;

signed main(){
	int n; cin >> n;
	vector<array<int,2>>a(n);

	map<pair<int,int>, int>node;

	for(int i = 0; i < n; i ++) {
		cin >> a[i][0] >> a[i][1];
		node[{a[i][0], a[i][1]}] ++;
	}
	int ans = 0;

	for(int i = 0; i < n; i ++) {
		map<int,vector<int>>st;

		for(int j = 0; j < n; j ++) {
			int dis = (a[i][0] - a[j][0]) * (a[i][0] - a[j][0]) + (a[i][1] - a[j][1]) * (a[i][1] - a[j][1]); 	
			if(dis)st[dis].push_back(j);
		}

		for(auto x: st) {
			vector<int>&no = x.second;
			int sum = no.size();
			ans += sum * (sum - 1) / 2;
			
			int del = 0;
			for(int j = 0; j < no.size(); j ++) {
				int x1 = a[i][0], y1 = a[i][1];
				int x2 = a[no[j]][0], y2 = a[no[j]][1];
				int x3 = x1 * 2 - x2, y3 = y1 * 2 - y2;
				del += (node[{x3, y3}]);
			}
			ans -= (del / 2);
		}
	}
	cout << ans << endl;
	return 0;
}

2、python3

python 复制代码
n = int(input())
a = [list(map(int, input().split())) for i in range(n)]
node = {}
for x, y in a:
    key = (x, y)
    if key not in node:
        node[key] = 1
    else:
        node[key] += 1
ans = 0
dis = [[0] * n for i in range(n)]
for i in range(n):
    for j in range(i + 1, n):
        x1, y1 = a[i]
        x2, y2 = a[j]
        d = (x1 - x2) ** 2 + (y1 - y2) ** 2
        dis[i][j] = d
        dis[j][i] = d

st = {}
for i in range(n):
    st.clear()
    x1, y1 = a[i]
    for j in range(n):
        if dis[i][j]:
            if dis[i][j] not in st:
                st[dis[i][j]] = [j]
            else:
                st[dis[i][j]].append(j)

    for d,no in st.items():
        sum = len(no)
        ans += sum * (sum - 1) // 2
        dell = 0
        for j in no:
            x2, y2 = a[j]
            x3 = x1 * 2 - x2
            y3 = y1 * 2 - y2
            if (x3, y3) in node:
                dell += node[(x3, y3)]
        ans -= (dell // 2)
print(ans)

3、Java

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        List<int[]> a = new ArrayList<>();
        Map<String, Integer> node = new HashMap<>();
        for(int i = 0; i < n; i ++) {
            int x = sc.nextInt();
            int y = sc.nextInt();
            a.add(new int[]{x, y});
            String no = x + "#" + y;
            node.put(no, node.getOrDefault(no, 0) + 1);
        }
        long ans = 0;
        for(int i = 0; i < n; i ++) {
            Map<Long, List<Integer>> st = new HashMap<>();
            for(int j = 0; j < n; j ++) {
                int x1 = a.get(i)[0], y1 = a.get(i)[1];
                int x2 = a.get(j)[0], y2 = a.get(j)[1];
                long dis = (long)Math.pow(x1 - x2, 2) + (long)Math.pow(y1 - y2, 2);
                if(dis == 0)continue;
                if(st.get(dis) == null)
                    st.put(dis, new ArrayList<Integer>());
                st.get(dis).add(j);
            }
            for(Map.Entry<Long, List<Integer>> x: st.entrySet()){
                List<Integer>no = x.getValue();
                long sum = no.size();
                ans += sum * (sum - 1) / 2;
                long del = 0;
                for(int j = 0; j < no.size(); j ++) {
                    int x1 = a.get(i)[0], y1 = a.get(i)[1];
                    int x2 = a.get(no.get((j)))[0], y2 = a.get(no.get((j)))[1];
                    int x3 = x1 * 2 - x2, y3 = y1 * 2 - y2;
                    if(node.get(x3 + "#" + y3) != null)
                        del += node.get(x3 + "#" + y3);
                }
                ans -= del / 2;
            }
        }
        System.out.println(ans);
    }
}   }
}
相关推荐
羑悻的小杀马特19 分钟前
C++多线程同步工具箱:call_once精准触发、lock_guard/unique_lock智能管理,打造无死锁程序!
c++·多线程·死锁·lock_guard·unique_lock·call_once
电子_咸鱼19 分钟前
【QT——信号和槽(1)】
linux·c语言·开发语言·数据库·c++·git·qt
CoderYanger25 分钟前
D.二分查找-基础-2529. 正整数和负整数的最大计数
java·开发语言·数据结构·算法·leetcode·职场和发展
想唱rap25 分钟前
Linux下进程的控制
linux·运维·服务器·c++·算法
Queenie_Charlie36 分钟前
小明统计数组
数据结构·c++·set
郝学胜-神的一滴37 分钟前
Separate Buffer、InterleavedBuffer 策略与 OpenGL VAO 深度解析
开发语言·c++·程序人生·算法·游戏程序·图形渲染
java修仙传39 分钟前
力扣hot100:搜索插入位置
算法·leetcode·职场和发展
承渊政道3 小时前
C++学习之旅【C++类和对象(下)】
c++·学习·visual studio
枫叶丹43 小时前
【Qt开发】Qt窗口(九) -> QFontDialog 字体对话框
c语言·开发语言·数据库·c++·qt
旖旎夜光9 小时前
多态(11)(下)
c++·学习