結果

問題 No.321 (P,Q)-サンタと街の子供たち
ユーザー threepipes_sthreepipes_s
提出日時 2015-12-14 00:58:37
言語 Java19
(openjdk 21)
結果
AC  
実行時間 327 ms / 2,000 ms
コード長 4,190 bytes
コンパイル時間 3,491 ms
コンパイル使用メモリ 75,844 KB
実行使用メモリ 58,000 KB
最終ジャッジ日時 2023-09-21 03:10:21
合計ジャッジ時間 12,892 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 44 ms
49,492 KB
testcase_01 AC 44 ms
49,428 KB
testcase_02 AC 44 ms
47,968 KB
testcase_03 AC 43 ms
47,792 KB
testcase_04 AC 43 ms
49,216 KB
testcase_05 AC 44 ms
49,296 KB
testcase_06 AC 44 ms
49,396 KB
testcase_07 AC 44 ms
49,300 KB
testcase_08 AC 44 ms
49,212 KB
testcase_09 AC 44 ms
49,268 KB
testcase_10 AC 45 ms
49,272 KB
testcase_11 AC 45 ms
49,396 KB
testcase_12 AC 45 ms
49,392 KB
testcase_13 AC 45 ms
49,552 KB
testcase_14 AC 228 ms
57,052 KB
testcase_15 AC 317 ms
57,396 KB
testcase_16 AC 196 ms
55,652 KB
testcase_17 AC 52 ms
49,384 KB
testcase_18 AC 217 ms
56,032 KB
testcase_19 AC 242 ms
57,088 KB
testcase_20 AC 313 ms
57,464 KB
testcase_21 AC 234 ms
56,996 KB
testcase_22 AC 154 ms
55,616 KB
testcase_23 AC 287 ms
57,616 KB
testcase_24 AC 159 ms
55,576 KB
testcase_25 AC 221 ms
57,164 KB
testcase_26 AC 304 ms
58,000 KB
testcase_27 AC 249 ms
57,464 KB
testcase_28 AC 259 ms
57,188 KB
testcase_29 AC 327 ms
57,708 KB
testcase_30 AC 104 ms
53,196 KB
testcase_31 AC 78 ms
51,268 KB
testcase_32 AC 213 ms
56,576 KB
testcase_33 AC 214 ms
56,660 KB
testcase_34 AC 187 ms
55,924 KB
testcase_35 AC 277 ms
57,408 KB
testcase_36 AC 109 ms
54,312 KB
testcase_37 AC 233 ms
56,976 KB
testcase_38 AC 209 ms
56,692 KB
testcase_39 AC 149 ms
55,624 KB
testcase_40 AC 295 ms
57,720 KB
testcase_41 AC 166 ms
55,496 KB
testcase_42 AC 284 ms
57,480 KB
testcase_43 AC 195 ms
55,668 KB
testcase_44 AC 251 ms
54,880 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.util.ArrayDeque;
import java.util.HashMap;
import java.util.Queue;
 
public class Main {
	public static void main(String[] args) throws NumberFormatException,
	IOException {Solve solve = new Solve();solve.solve();}
}
class Solve{
	class Pos{
		int x, y;
		Pos(int x, int y){
			this.x = x;
			this.y = y;
		}
	}
	void solve() throws NumberFormatException, IOException{
		ContestScanner in = new ContestScanner();
		Writer out = new Writer();
		
//		int a = in.nextInt();
//		int b = in.nextInt();
//		int[] dx = {a, a, b, b, -a, -a, -b, -b};
//		int[] dy = {b, -b, a, -a, a, -a, b, -b};
//		int h = 41;
//		int w = 41;
//		boolean[][] map = new boolean[41][41];
//		Queue<Pos> qu = new ArrayDeque<>();
//		qu.add(new Pos(20, 20));
//		while(!qu.isEmpty()){
//			Pos p = qu.poll();
//			if(map[p.y][p.x]) continue;
//			map[p.y][p.x] = true;
//			for(int i=0; i<dx.length; i++){
//				final int nx = dx[i]+p.x;
//				final int ny = dy[i]+p.y;
//				if(nx<0||nx>=41||ny<0||ny>=41) continue;
//				qu.add(new Pos(nx, ny));
//			}
//		}
//		for(int i=0; i<h; i++){
//			for(int j=0; j<w; j++){
//				System.out.print(map[i][j]?'o':'x');
//			}
//			System.out.println();
//		}
		int p = in.nextInt();
		int q = in.nextInt();
		int g;
		if(p==0&&q==0){
			int n = in.nextInt();
			int count = 0;
			for(int i=0; i<n; i++){
				int x = in.nextInt();
				int y = in.nextInt();
				if(x==0&&y==0)count++;
			}
			System.out.println(count);
			return;
		}
		if(p==0||q==0){
			g = p+q;
		}else g = gcd(p, q);
		int diff = Math.max(p, q)/g-Math.min(p, q)/g;
		int n = in.nextInt();
		int count = 0;
		for(int i=0; i<n; i++){
			int x = in.nextInt();
			int y = in.nextInt();
			if(x%g==0&&y%g==0){
				x /= g;
				y /= g;
				if(diff%2!=0||(x+y)%2==0){
					count++;
					continue;
				}
			}
		}
//		int g;
//		if(a==0||b==0){
//			g = a+b;
//		}else g = gcd(a, b);
//		int diff = Math.max(a, b)/g-Math.min(a, b)/g;
//		for(int i=0; i<h; i++){
//			for(int j=0; j<w; j++){
//				int y = i-20;
//				int x = j-20;
//				if(x%g==0&&y%g==0){
//					if(diff%2!=0||(x+y)%2==0)
//					System.out.print('o');
//					else System.out.print('x');
//				}else System.out.print('x');
//			}
//			System.out.println();
//		}
		System.out.println(count);
	}
	static int gcd(int a, int b){
		return b == 0 ? a : gcd(b, a % b);
	}
	
}

class MultiSet<T> extends HashMap<T, Integer>{
	@Override
	public Integer get(Object key){return containsKey(key)?super.get(key):0;}
	public void add(T key,int v){put(key,get(key)+v);}
	public void add(T key){put(key,get(key)+1);}
	public void sub(T key){
		final int num = get(key);
		if(num==1) remove(key);
		else put(key, num-1);
	}
}
class Timer{
	long time;
	public void set(){time = System.currentTimeMillis();}
	public long stop(){return System.currentTimeMillis()-time;}
}
class Writer extends PrintWriter{
	public Writer(String filename) throws IOException
	{super(new BufferedWriter(new FileWriter(filename)));}
	public Writer() throws IOException{super(System.out);}
}
class ContestScanner {
	private BufferedReader reader;
	private String[] line;
	private int idx;
	public ContestScanner() throws FileNotFoundException 
	{reader = new BufferedReader(new InputStreamReader(System.in));}
	public ContestScanner(String filename) throws FileNotFoundException
	{reader = new BufferedReader(new InputStreamReader(new FileInputStream(filename)));}
	public String nextToken() throws IOException {
		if (line == null || line.length <= idx) {
			line = reader.readLine().trim().split(" ");
			idx = 0;
		}
		return line[idx++];
	}
	public String readLine() throws IOException{return reader.readLine();}
	public long nextLong() throws IOException, NumberFormatException
	{return Long.parseLong(nextToken());}
	public int nextInt() throws NumberFormatException, IOException
	{return (int) nextLong();}
	public double nextDouble() throws NumberFormatException, IOException 
	{return Double.parseDouble(nextToken());}
}
0