結果

問題 No.321 (P,Q)-サンタと街の子供たち
ユーザー threepipes_sthreepipes_s
提出日時 2015-12-14 00:58:37
言語 Java21
(openjdk 21)
結果
AC  
実行時間 279 ms / 2,000 ms
コード長 4,190 bytes
コンパイル時間 2,266 ms
コンパイル使用メモリ 79,452 KB
実行使用メモリ 58,396 KB
最終ジャッジ日時 2024-07-06 21:49:11
合計ジャッジ時間 10,725 ms
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 47 ms
50,672 KB
testcase_01 AC 49 ms
50,284 KB
testcase_02 AC 46 ms
50,580 KB
testcase_03 AC 47 ms
50,244 KB
testcase_04 AC 46 ms
50,488 KB
testcase_05 AC 47 ms
50,204 KB
testcase_06 AC 46 ms
50,260 KB
testcase_07 AC 47 ms
50,328 KB
testcase_08 AC 46 ms
50,464 KB
testcase_09 AC 45 ms
50,276 KB
testcase_10 AC 47 ms
50,540 KB
testcase_11 AC 48 ms
50,280 KB
testcase_12 AC 47 ms
50,580 KB
testcase_13 AC 46 ms
50,500 KB
testcase_14 AC 207 ms
57,212 KB
testcase_15 AC 279 ms
58,328 KB
testcase_16 AC 179 ms
55,628 KB
testcase_17 AC 52 ms
50,248 KB
testcase_18 AC 197 ms
55,732 KB
testcase_19 AC 216 ms
57,080 KB
testcase_20 AC 274 ms
58,396 KB
testcase_21 AC 210 ms
57,100 KB
testcase_22 AC 144 ms
55,700 KB
testcase_23 AC 249 ms
57,348 KB
testcase_24 AC 152 ms
55,664 KB
testcase_25 AC 210 ms
57,140 KB
testcase_26 AC 265 ms
57,904 KB
testcase_27 AC 224 ms
57,356 KB
testcase_28 AC 230 ms
57,368 KB
testcase_29 AC 278 ms
58,316 KB
testcase_30 AC 100 ms
53,188 KB
testcase_31 AC 71 ms
51,144 KB
testcase_32 AC 196 ms
56,484 KB
testcase_33 AC 194 ms
56,388 KB
testcase_34 AC 173 ms
55,908 KB
testcase_35 AC 234 ms
58,028 KB
testcase_36 AC 103 ms
53,016 KB
testcase_37 AC 213 ms
57,208 KB
testcase_38 AC 199 ms
55,948 KB
testcase_39 AC 149 ms
55,776 KB
testcase_40 AC 263 ms
57,708 KB
testcase_41 AC 159 ms
55,976 KB
testcase_42 AC 249 ms
57,352 KB
testcase_43 AC 183 ms
55,500 KB
testcase_44 AC 246 ms
57,344 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