NEUQ-ACM实验班训练002题解(1-10)最终稿

本文介绍了ACM竞赛中的几道题目,包括求两圆相交面积、电影时间安排、谷歌招聘素数问题、汉诺塔、数字三角形最大路径和、字母塔构造及字母表排列。解题涉及几何计算、搜索算法、数学思维,如角度计算、排序选择、素数判断、递归与动态规划等。
摘要由CSDN通过智能技术生成

7-6 求两圆相交的面积 (10分)
给定2圆的圆心坐标和半径,计算并输出两圆相交的面积,如果是外切或不相交,则输出0,圆周率取函数值acos(-1)。

输入格式:
输入6个整数x1 y1 r1 x2 y2 r2,分别表示两圆的圆心(x1,y1),(x2,y2)和半径r1,r2。

输出格式:
根据圆的位置关系,输出其相交部分的面积(保留2位小数)。

输入样例:
在这里给出2组输入。例如:

0 0 1 2 2 1
2 0 2 5 2 3

输出样例:
在这里给出相应的输出。例如:

0.00
3.22

分析
在这里插入图片描述
这里需要注意,1:∠(o1ao2)不是直角,不能直接勾股定理;2:o1o2垂直平分AB但反过来不成立,左右并不是全等

面积算法:S(o1)-S▲(o1AB)//(右边的弓形)+S(o2)-S▲(o2AB)//(左边的弓形)

难点:中间的多变量设计

#include<bits/stdc++.h>
using namespace std;
const double p=acos(-1);
int main(){
   
     
     long long  x1,y1,r1,x2,y2,r2;
     
     cin>>x1>>y1>>r1>>x2>>y2>>r2;
     
     double d=0;
     double l1,l2=0;
     
     l1=x1-x2;
     l2=y1-y2;
     
     if(l1*l1+l2*l2>=(r1+r2)*(r1+r2)||l1*l1+l2*l2<=(r1-r2)*(r1-r2)){
   
     	 printf("%.2f",0);//排除相切和相离。
	 }
	 
	 else{
   
	 	d=sqrt(l1*l1+l2*l2);
	 	
	    double ang1=acos((r1*r1+d*d-r2*r2)/(2*r1*d));//反三角函数的应用
	    double ang2=acos((r2*r2+d*d-r1*r1)/(2*r2*d));
	
	    double s1=r1*r1*(ang1);//原式为s1=p*r1*r1*(ang1/p),下同理
	    double s2=r2*r2*(ang2);
	    
	    double s3=r1*d*sin(ang1);
	    
	    printf("%.2f",s1+s2-s3);
     }
	 return 0;
}

7-7 看电影 (10分)
终于到周末了,明明是特别喜欢看电影。他想在一天内尽量多的看到完整的多部电影。 现在他把他喜欢的电影的播放时间表给你,希望你能帮他合理安排。

输入格式:
输入包含多组测试数据。每组输入的第一行是一个整数n(n<=100),表示明明喜欢的电影的总数。 接下来n行,每行输入两个整数si和ei(1<=i<=n),表示第i个电影的开始和结束时间,为了简化问题,每个时间都用一个正整数表示。 当n=0时,输入结束。

输出格式:
对于每组输入,输出能完整看到的电影的个数。

输入样例:
在这里给出一组输入。例如:

12
1 3
3 4
0 7
3 8
15 19
15 20
10 15
8 18
6 12
5 10
4 14
2 9
0
输出样例:
在这里给出相应的输出。例如:
5

分析:越早结束的一定越早开始,如果想看的越多,就一定要选越早结束的,看起来是搜索,实际是排序加选择

#include<bits/stdc++.h>
using namespace std;
struct film{
   
	int x;
	int y
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值