結果
| 問題 |
No.412 花火大会
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-04-22 00:16:37 |
| 言語 | Fortran (gFortran 14.2.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,223 bytes |
| コンパイル時間 | 433 ms |
| コンパイル使用メモリ | 33,920 KB |
| 実行使用メモリ | 13,888 KB |
| 最終ジャッジ日時 | 2024-06-27 05:31:23 |
| 合計ジャッジ時間 | 4,095 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 2 TLE * 1 -- * 15 |
ソースコード
module mdl
contains
recursive subroutine qsort(a,s,t)
integer*8::a(:),s,t,i,j,m
if(t-s<=1)return
i=s
j=t-1
m=a((s+t)/2)
do
do while(a(i)<m)
i=i+1
end do
do while(a(j)>m)
j=j-1
end do
if(i>=j)exit
a(i)=xor(a(i),a(j))
a(j)=xor(a(i),a(j))
a(i)=xor(a(i),a(j))
i=i+1
j=j-1
end do
call qsort(a,s,i)
call qsort(a,j+1,t)
end subroutine
end module
program main
use mdl
implicit none
integer*8::B,C,D,N,i,j,k,p,ans=0,arr(3),a(3)
integer*8,allocatable::E(:)
read(*,*)B,C,D
a(1)=B
a(2)=C
a(3)=D
call qsort(a,1_8,4_8)
read*,N
allocate(E(N))
read*,(E(i),i=1,N)
call qsort(E,int(1,8),int(size(E)+1,8))
do i=1,lshift(1,N)-1
if(popcnt(i)<3)cycle
p=1
do j=N-1,0,-1
if(mod(rshift(i,j),2)==1)then
arr(p)=E(j+1)
p=p+1
end if
if(p==4)exit
end do
if(a(1)<=arr(3).and.a(2)<=arr(2).and.a(3)<=arr(1))ans=ans+1
end do
print*,ans
end program