結果

問題 No.1004 サイコロの実装 (2)
ユーザー tsuishitsuishi
提出日時 2021-03-26 16:38:14
言語 C
(gcc 12.3.0)
結果
WA  
実行時間 -
コード長 1,934 bytes
コンパイル時間 239 ms
コンパイル使用メモリ 29,508 KB
実行使用メモリ 8,756 KB
最終ジャッジ日時 2023-08-18 22:48:35
合計ジャッジ時間 6,113 ms
ジャッジサーバーID
(参考情報)
judge14 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
8,756 KB
testcase_01 AC 1 ms
4,380 KB
testcase_02 AC 1 ms
4,380 KB
testcase_03 AC 0 ms
4,380 KB
testcase_04 AC 1 ms
4,380 KB
testcase_05 AC 1 ms
4,376 KB
testcase_06 AC 1 ms
4,380 KB
testcase_07 AC 1 ms
4,376 KB
testcase_08 AC 1 ms
4,376 KB
testcase_09 AC 0 ms
4,380 KB
testcase_10 AC 1 ms
4,376 KB
testcase_11 AC 1 ms
4,380 KB
testcase_12 AC 1 ms
4,380 KB
testcase_13 AC 0 ms
4,380 KB
testcase_14 AC 1 ms
4,376 KB
testcase_15 AC 1 ms
4,376 KB
testcase_16 AC 41 ms
4,380 KB
testcase_17 AC 153 ms
4,380 KB
testcase_18 AC 2 ms
4,380 KB
testcase_19 AC 14 ms
4,380 KB
testcase_20 AC 6 ms
4,380 KB
testcase_21 AC 123 ms
4,376 KB
testcase_22 AC 9 ms
4,380 KB
testcase_23 AC 18 ms
4,376 KB
testcase_24 AC 107 ms
4,376 KB
testcase_25 AC 80 ms
4,376 KB
testcase_26 WA -
testcase_27 WA -
testcase_28 WA -
testcase_29 TLE -
testcase_30 -- -
testcase_31 -- -
testcase_32 -- -
testcase_33 -- -
testcase_34 -- -
testcase_35 -- -
testcase_36 -- -
testcase_37 -- -
testcase_38 -- -
testcase_39 -- -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// Yukicoder №1004 サイコロの実装 (2) ★☆
// https://yukicoder.me/problems/no/1004
// ***********************
#define	lolong	long long
#define gc(c)	do{c = getchar_unlocked();}while(0)
#define pc(c)	putchar_unlocked(c)
	extern char getchar_unlocked(void);
	extern void putchar_unlocked(char c);
static char *GETWORD(char* str) {char c;char *cp;cp=&str[0];gc(c);while(c!=EOF){if((c==' ')||(c=='\n'))break;*cp++=c;gc(c);}*cp='\0';return &str[0];}
#define	str_len(a)	mystr_len_lim(a,9999)
static int mystr_len_lim(char *str,int lim){int i=0;do{if(str[i]=='\0')break;i++;}while(i<lim);return i;}
#define GETLINE(str)	do{char *p;fgets(str,sizeof(str),stdin);p=strchr(str,'\n');if(p)*p='\0';}while(0)
static int GETLINEINT(void) {char s[34];GETLINE(s);return atoi(s);}
static int GETWORDINT(void) {char s[34];GETWORD(s);return atoi(s);}
static long GETWORDLONG(void) {char s[34];GETWORD(s);return atol(s);}
static int max(int a,int b){if(a>b){return a;}return b;}
static int min(int a,int b){if(a<b){return a;}return b;}
#define REP(a,b) for(int a=0;a<(b);++a)
#define REP1(a,b) for(int a=1;a<=(b);++a)
// *********************
int	a,b;
unsigned int	Bud= 0;
unsigned int randhatena() {
	Bud = Bud * a + b;
	//fprintf(stderr,"%u,",Bud);
	return Bud;
}
// *********************
void play( int *wi, int *bl, int *km){
	unsigned int	d;
	d = randhatena() % (unsigned int)6 + (unsigned int)1;
	(*km) += (int)d;
	if( *km & 1 ) (*bl)++;
	else (*wi)++;
}
// *********************
int main( void ) {
	int	x0,N;
	int	b1=0,w1=0,i1=0;
	int	b2=0,w2=0,i2=0;

	scanf( "%d %d %d %d", &a, &b, &x0, &N );

	Bud = (unsigned int)x0;

	REP(i,N) {
		play( &b1, &w1 , &i1 );
		fprintf(stderr,"%d,", i1);
		play( &b2, &w2 , &i2 );
		fprintf(stderr,"%d\n", i2);
	}
	fprintf(stderr,"a is B%d,W%d\n", b1,w1);
	fprintf(stderr,"b is B%d,W%d\n", b2,w2);
	printf("%d %d\n",min(b1,w1), min(b2,w2) );
}
0