PAT-B 1088 三人行【暴力列舉】
PAT-B 1088 三人行
https://pintia.cn/problem-sets/994805260223102976/problems/1038429286185074688
題目
子曰:“三人行,必有我師焉。擇其善者而從之,其不善者而改之。”本題給定甲、乙、丙三個人的能力值關係為:甲的能力值確定是 2 位正整數;把甲的能力值的 2 個數字調換位置就是乙的能力值;甲乙兩人能力差是丙的能力值的 X 倍;乙的能力值是丙的 Y 倍。請你指出誰比你強應“從之”,誰比你弱應“改之”。
輸入
輸入在一行中給出三個數,依次為:M(你自己的能力值)、X 和 Y。三個數字均為不超過 1000 的正整數。
輸出
在一行中首先輸出甲的能力值,隨後依次輸出甲、乙、丙三人與你的關係:如果其比你強,輸出 Cong
;平等則輸出 Ping
;比你弱則輸出 Gai
。其間以 1 個空格分隔,行首尾不得有多餘空格。注意:如果解不唯一,則以甲的最大解為準進行判斷;如果解不存在,則輸出 No Solution
。
樣例輸入
48 3 7
樣例輸出
48 Ping Cong Gai
分析
注意,甲、乙的能力值為整數,但是丙的能力值可能為小數,因此需要將c設定為double型別。
C++程式
#include<iostream>
#include<string>
#include<cmath>
using namespace std;
string solve(double m,double x)
{
string s;
if(m<x)
s="Cong";
else if(m==x)
s="Ping";
else
s="Gai";
return s;
}
int main()
{
int m,a,b,x,y;//a、b、c分別表示甲、乙、丙
double c;//丙可能為小數
cin>>m>>x>>y;
for(a=99;a>9;a--)//甲是兩位數
{
b=(a%10)*10+a/10;//乙
c=fabs(a-b)/x;//丙 甲乙兩人能力差是丙的能力值的 X 倍
if(c*y==b)//乙的能力值是丙的 Y 倍
{
cout<<a<<" "<<solve(m,a)<<" "<<solve(m,b)<<" "<<solve(m,c)<<endl;
break;//跳出
}
}
if(a==9) cout<<"No Solution"<<endl;
return 0;
}
相關文章
- 藍橋杯——暴力列舉篇
- (桶暴力列舉gcd) CF1627D Not AddingGC
- 6343 密碼鎖 CSP-S 2023年 暴力列舉密碼
- 5211 導彈攔截 普及組 NOIP2010 暴力列舉
- Java 列舉、JPA 和 PostgreSQL 列舉JavaSQL
- 列舉
- 列舉和列舉的取值範圍
- 1088 Rational Arithmetic (20分)
- Java列舉Java
- scala 列舉
- Enumeration列舉
- 列舉類
- PAT-B 1066 影象過濾【陣列】陣列
- C# 列舉與位列舉概述C#
- Java 列舉(enum)Java
- 列舉工具類
- Swift-列舉Swift
- TypeScript 列舉enumTypeScript
- 列舉型別型別
- java列舉類Java
- 列舉比較
- TypeScript 列舉指南TypeScript
- 自定義列舉
- PAT-B 1030 完美數列【二分】
- PAT-B 1084 外觀數列 【模擬】
- Java列舉-通過值查詢對應的列舉Java
- Java enum列舉類詳解 列舉的常見用法Java
- springboot mybatis列舉配置(每次只需新增一個列舉類即可)Spring BootMyBatis
- PAT-B 1019 數字黑洞【陣列+模擬】陣列
- PAT-B 1049 數列的片段和【規律】
- PAT-B 1092 最好吃的月餅【陣列】陣列
- PAT-B 1083 是否存在相等的差【陣列】陣列
- iOS 列舉器NSEnumeratoriOS
- Java基礎--列舉Java
- golang 常量與列舉Golang
- TS — 列舉(詳解)
- ENUM列舉型別型別
- Java列舉解讀Java