提出 #67335270


ソースコード 拡げる

#include <bits/stdc++.h>
#define ll long long
#define mk make_pair
#define int long long
using namespace std;

const int Maxn=1e6+7;
const double eps=1e-15;
int n;
int a[Maxn],b[Maxn];
int T;
int id[Maxn];

signed main(){
    cin>>T;
    while(T--){
        cin>>n;
        for(int i=1;i<=n;i++) cin>>a[i],b[i]=abs(a[i]),id[i]=i;

        sort(id+1,id+n+1,[](int x,int y){
            return b[x]<b[y];
        });
        sort(b+1,b+n+1);
        if(b[1]==b[2]){
            int a1=0,a2=0;
            for(int i=1;i<=n;i++) if(b[i]!=b[1]) a1=-1;
            if(a1<0){
                puts("No");
                continue;
            }
            for(int i=1;i<=n;i++){
                if(a[i]<0) a1++;
                else a2++;
            }
            if(abs(a1-a2)<=1 or a1==n or a2==n) puts("Yes");
            else puts("No");
            continue;
        }
        bool tag=1; bool p=1;
        if(1ll*a[id[1]]*a[id[2]]<0) p=0;
        for(int i=3;i<=n;i++){
            bool t=1;
            if(1ll*a[id[i]]*a[id[i-1]]<0) t=0;
            if(p!=t) tag=0;

            if(1ll*b[i]*b[1]!=1ll*b[2]*b[i-1]){
                tag=0;
            }
        }
        if(tag) puts("Yes");
        else puts("No");
    }

    return 0;
}

提出情報

提出日時
問題 D - Make Geometric Sequence
ユーザ AceTaffy_
言語 C++ 20 (gcc 12.2)
得点 425
コード長 1293 Byte
結果 AC
実行時間 85 ms
メモリ 8180 KiB

ジャッジ結果

セット名 Sample All
得点 / 配点 0 / 0 425 / 425
結果
AC × 1
AC × 32
セット名 テストケース
Sample 00_sample_00.txt
All 00_sample_00.txt, 01_random_01.txt, 01_random_02.txt, 01_random_03.txt, 01_random_04.txt, 01_random_05.txt, 01_random_06.txt, 01_random_07.txt, 01_random_08.txt, 01_random_09.txt, 01_random_10.txt, 01_random_11.txt, 01_random_12.txt, 01_random_13.txt, 01_random_14.txt, 01_random_15.txt, 01_random_16.txt, 01_random_17.txt, 01_random_18.txt, 01_random_19.txt, 01_random_20.txt, 01_random_21.txt, 01_random_22.txt, 01_random_23.txt, 01_random_24.txt, 01_random_25.txt, 01_random_26.txt, 01_random_27.txt, 01_random_28.txt, 01_random_29.txt, 01_random_30.txt, 02_handmade_31.txt
ケース名 結果 実行時間 メモリ
00_sample_00.txt AC 1 ms 3552 KiB
01_random_01.txt AC 40 ms 3504 KiB
01_random_02.txt AC 82 ms 6444 KiB
01_random_03.txt AC 82 ms 7404 KiB
01_random_04.txt AC 84 ms 3500 KiB
01_random_05.txt AC 82 ms 4868 KiB
01_random_06.txt AC 22 ms 3552 KiB
01_random_07.txt AC 59 ms 8172 KiB
01_random_08.txt AC 85 ms 3496 KiB
01_random_09.txt AC 84 ms 3536 KiB
01_random_10.txt AC 47 ms 3500 KiB
01_random_11.txt AC 82 ms 6196 KiB
01_random_12.txt AC 84 ms 3492 KiB
01_random_13.txt AC 83 ms 3504 KiB
01_random_14.txt AC 84 ms 3536 KiB
01_random_15.txt AC 82 ms 4028 KiB
01_random_16.txt AC 84 ms 3504 KiB
01_random_17.txt AC 83 ms 3380 KiB
01_random_18.txt AC 61 ms 3508 KiB
01_random_19.txt AC 59 ms 8180 KiB
01_random_20.txt AC 39 ms 3548 KiB
01_random_21.txt AC 83 ms 6344 KiB
01_random_22.txt AC 83 ms 3636 KiB
01_random_23.txt AC 51 ms 3548 KiB
01_random_24.txt AC 83 ms 7712 KiB
01_random_25.txt AC 84 ms 3492 KiB
01_random_26.txt AC 84 ms 3504 KiB
01_random_27.txt AC 68 ms 4088 KiB
01_random_28.txt AC 82 ms 6332 KiB
01_random_29.txt AC 84 ms 3516 KiB
01_random_30.txt AC 41 ms 4164 KiB
02_handmade_31.txt AC 1 ms 3540 KiB