提交记录 21986


用户 题目 状态 得分 用时 内存 语言 代码长度
RainPPR mmmd1k. 测测你的双精度矩阵乘法-1k Accepted 100 727.415 ms 8200 KB C++ 655 B
提交时间 评测时间
2024-07-23 10:55:06 2024-07-23 10:55:10
#define idx(i, j) ((i) * n + (j))

#define expect(x, v) __builtin_expect(x, v)
#define likely(x) expect(!!(x), 1)
#define unlikely(x) expect(!!(x), 0)

#define unreachable() __builtin_unreachable()
#define assume(x) ({ if (!(x)) unreachable(); })

#define prefetch __builtin_prefetch

void matrix_multiply(int n, const double *A, const double *B, double *C) {
	for (int i = 0; i < n; i++)
		for (int j = 0; j < n; j++)
			C[idx(i, j)] = 0;
	prefetch(A, 0, 1), prefetch(B, 0, 1), prefetch(C, 1, 1);
	for (int i = 0; i < n; i++) {
		for (int k = 0; k < n; k++) {
		for (int j = 0; j < n; j++) {
				C[idx(i, j)] += A[idx(i, k)] * B[idx(k, j)];
			}
		}
	}
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #1727.415 ms8 MB + 8 KBAcceptedScore: 100


Judge Duck Online | 评测鸭在线
Server Time: 2024-09-08 08:47:57 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用