二刷
一开始只能过两个测试点,后来一看原来是先输出甲的成绩,我以为是输出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;
}