[PAT 乙级] 1088 三人行 (20 分)——(逻辑题)2021-08-11

在这里插入图片描述

二刷

一开始只能过两个测试点,后来一看原来是先输出甲的成绩,我以为是输出m(甲和m的测试用例值一样)。。。。。。。。。

#include <iostream>
#include <cmath>
using namespace std;
int m, x, y;
string cmp(double p){
    if(m==p) return "Ping";
    else if(m<p) return "Cong";
    else return "Gai";
}
int main(){
    cin>>m>>x>>y;
    double jia,yi,bing;
    int a,b,count=0;
    for(int i=10;i<=99;i++){
        a=i;
        b=(i%10)*10+(i/10);
        if(abs(a-b)*1.0/x==b*1.0/y) {
            count++;
            jia=a,yi=b,bing=abs(a-b)*1.0/x;
        }
    }
    if(count==0) cout<<"No Solution";
    else cout<<jia<<" "<<cmp(jia)<<" "<<cmp(yi)<<" "<<cmp(bing);
    return 0;
}

毫无思路,直接看答案

分析:丙不⼀定是int值,可能是4.5这样的数字~所以要⽤double存储丙~i、j、k分别代表甲⼄丙~i从
99遍历到10找到符合题意的那个数字即可~

#include <iostream>
#include <cmath>
using namespace std;
int m, x, y;
void print(double t) {
	if (m == t) printf(" Ping");
	else if (m < t) printf(" Cong");
	else printf(" Gai");
}
int main() {
	scanf("%d %d %d", &m, &x, &y);
	for (int i = 99; i >= 10; i--) {//甲:两位数枚举
		int j = i % 10 * 10 + i / 10;//乙:原先的个位数*10+原先的十位数
		double k = abs(j - i) * 1.0 / x;//丙
		if (j == k * y) {//如果满足条件
			cout << i;//输出甲
			print(i); print(j); print(k);//比较以及打印函数
			return 0;
		}
	}
	cout << "No Solution";
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值