結果
| 問題 |
No.751 Frac #2
|
| コンテスト | |
| ユーザー |
SugarDragon5
|
| 提出日時 | 2018-11-09 21:37:34 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,949 bytes |
| コンパイル時間 | 1,578 ms |
| コンパイル使用メモリ | 168,680 KB |
| 実行使用メモリ | 6,824 KB |
| 最終ジャッジ日時 | 2024-11-21 05:43:09 |
| 合計ジャッジ時間 | 2,704 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 9 WA * 27 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define FOR(i,n,m) for(int i=(n);i<(m);i++)
#define REP(i,n) FOR(i,0,n)
#define REPR(i,n) for(int i=(n);i>=0;i--)
#define all(vec) vec.begin(),vec.end()
using vi=vector<int>;
using vvi=vector<vi>;
using vl=vector<ll>;
using vvl=vector<vl>;
using P=pair<int,int>;
using PP=pair<int,P>;
using Pl=pair<ll,ll>;
using PPl=pair<ll,Pl>;
using vs=vector<string>;
#define fi first
#define se second
#define pb push_back
template<class T>bool chmax(T &a,const T &b){if(a<b){a=b;return true;}return false;}
template<class T>bool chmin(T &a,const T &b){if(a>b){a=b;return true;}return false;}
const ll MOD=1000000007LL;
const int INF=1<<30;
const ll LINF=1LL<<60;
ll gcd(ll a,ll b){
return b==0?a:gcd(b,a%b);
}
ll lcm(ll a,ll b){
return a/gcd(a,b)*b;
}
ll extgcd(ll a,ll b,ll &x,ll &y){
if(!b){
x=1;y=0;
return a;
}
ll d=extgcd(b,a%b,y,x);
y-=a/b*x;
return d;
}
struct Bunsu{
ll x,y;
Bunsu():x(0),y(1){}
Bunsu(ll x,ll y):x(x),y(y){
yakubun();
}
bool operator<(Bunsu a){
return 1.0*x/y<1.0*a.x/a.y;
}
void yakubun(){
ll g=gcd(x,y);
x/=g;
y/=g;
if(y<0){
x*=-1;y*=-1;
}
}
Bunsu operator*=(ll t){
x*=t;
yakubun();
return *this;
}
Bunsu operator/=(ll t){
y*=t;
yakubun();
return *this;
}
Bunsu operator/=(Bunsu a){
x*=a.y;
y*=a.x;
yakubun();
return *this;
}
};
int main(){
int n;
cin>>n;
Bunsu ans(1,1);
REP(i,n){
int x;
cin>>x;
if(i){
ans/=x;
}else{
ans*=x;
}
}
int m;
cin>>m;
REP(i,m){
int x;
cin>>x;
if(i){
ans*=x;
}else{
ans/=x;
}
}
cout<<ans.x<<" "<<ans.y<<endl;
return 0;
}
SugarDragon5