XTU OJ 1183 sum & times

Description

题目描述

整数a,b,其中a+b = c,a*b = d,已知c和d,问是否存在a和b?

输入

第一行是一个整数K,表示样例个数。 每个样例占1行,两个整数c和d,0≤c,d≤109。

输出

每行输出一个样例的结果,a和b(a≤b),之间用一个空格隔开。如果存在多组,输出a最小的那一组; 如果不存在这样的a和b,输出“None”(引号不用输出)。

样例输入
2
5 6
7 11
样例输出
2 3
None

直接套用公式,因为a要从小开始输,因此设a为自变量,然后++;

a+b=c,所以b = c-a,然后判断b*a是不是等于d,默认a<b,所以a只需要加到c/2的一半(若a=b,2a=c)。

#include<stdio.h>
int main()
{
	int k;
	scanf("%d", &k);
	while(k--){
		int c,d;
		scanf("%d %d", &c,&d);
		int n = c/2+1;
		int a,b;
		int flag=0;
		for(a=0;a<n;a++){
			b = c-a;
			if(b*a==d){
				flag=1;
				break;
			}
		}
		if(flag==0)printf("None\n");
		else if(flag==1)printf("%d %d\n", a,b);
	}
	return 0;
}

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值