import sys inf = 1<<60 N, S, B = map(int, sys.stdin.readline().rstrip().split()) H = list(map(int, sys.stdin.readline().rstrip().split())) def kiriage(a, b): return (a+b-1)//b def chmax(DP,i,v): if DP[i] < v: DP[i] = v def chmin(DP,i,v): if DP[i] > v: DP[i] = v DP = [-1] * (S + 1) DP[S] = H[0] # DP[stamina] stamina で到達できる max height # in-place でやる for i in range(N - 1): # N - 1 ターン landing = False for j in range(S + 1): # j: stamina DP[j]: height if DP[j] == -1: continue # 今いる高さ -> 次の足場の高低差 diff = max(0, H[i + 1] - DP[j]) cost = kiriage(diff, B) # stamina==j から cost を捻出できるか? if j >= cost: chmax(DP, j - cost, DP[j] + cost * B) # 捻出できる=次の足場上に浮いていられる landing = True # 捻出できないなら その高さ・スタミナからは到達不能 if landing: # 足場 H[i + 1] に着地した場合のステータスも考慮 DP[S] = max(DP[S], H[i + 1]) else: #途中経過でlanding できない足場があったらその時点で詰み exit(print('No')) print('Yes')