LeetCode 825. 适龄的朋友 分类处理[1]

825. 适龄的朋友  https://leetcode-cn.com/problems/friends-of-appropriate-ages/

人们会互相发送好友请求,现在给定一个包含有他们年龄的数组,ages[i] 表示第 i 个人的年龄。

当满足以下条件时,A 不能给 B(A、B不为同一人)发送好友请求:

  • age[B] <= 0.5 * age[A] + 7
  • age[B] > age[A]
  • age[B] > 100 && age[A] < 100

否则,A 可以给 B 发送好友请求。

注意如果 A 向 B 发出了请求,不等于 B 接受了 A 的请求。而且,人们不会给自己发送好友请求。 

求总共会发出多少份好友请求?

示例 1:输入: [16,16] 输出: 2 解释: 二人可以互发好友申请。

示例 2:输入: [16,17,18] 输出: 2 解释: 好友请求可产生于 17 -> 16, 18 -> 17.

示例 3:输入: [20,30,100,110,120]输出: 3 解释: 好友请求可产生于 110 -> 100, 120 -> 110, 120 -> 100.

说明:

  • 1 <= ages.length <= 20000.
  • 1 <= ages[i] <= 120.

思路:按照年龄归类,分类处理。

          存在问题,1, 3个关系之间是或 不是 并。

                            2.并不是16岁就不能给16岁发哦,是同一个人不能发,两个同是16岁的可以发。

                           3.注意if(dp[i][j]&&i==j)                 sum+=(agenum[i]-1)*agenum[j];

class Solution {
	public:
		const int N=122;
		bool dp[122][122];
		int agenum[122];
		int numFriendRequests(vector<int>& ages) {

			for(int i=1; i<=120; i++) {
				for(int j=1; j<=120; j++) {
					/*
					 age[B] <= 0.5 * age[A] + 7
					 age[B] > age[A]
					 age[B] > 100 && age[A] < 100*/
					if((double)j<=0.5*(double)i+7
					        ||  j>i
					        ||  j>100 && i<100)
						dp[i][j]=false;
					else dp[i][j]=true;

				}
			}

			// 统计数量
			int n=ages.size();
			memset(agenum,0,sizeof(agenum));
			for(int i=0; i<n; i++) {
				agenum[ages[i]]++;
			}
			//分批处理
			int sum=0;
			for(int i=1; i<=120; i++) {
				if(!agenum[i]) continue;
				for(int j=1; j<=120; j++) {
					if(!agenum[j]) continue;
					//cout<<i<<" "<<j<<" "<<dp[i][j]<<endl;
					if(dp[i][j]&&i!=j)
						sum+=agenum[i]*agenum[j];
					if(dp[i][j]&&i==j)
						sum+=(agenum[i]-1)*agenum[j];
				}
			}
			return sum;
		}
};

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值