力扣竞赛勋章 | 排名分数计算脚本

代码修改自:https://leetcode.cn/circle/discuss/6gnvEj/
原帖子的代码无法正常运行。

力扣竞赛勋章介绍

https://leetcode.cn/circle/discuss/0fKGDu/

在这里插入图片描述

如果你想知道自己上多少分可以拿到对应的勋章,那么篇文章会解决你的问题!

竞赛评分算法

https://leetcode.cn/circle/article/neTUV4/

脚本(本文的重点内容)

#!/usr/bin/env python3

import json
import sys

import requests

# 力扣目前勋章的配置
RATING = 1600       # 从1600分以上才开始算人
GUARDIAN = 0.05
KNIGHT = 0.25
# 查询的地址为全国还是全球?很关键
GLOBAL = False
# 二分查找的右端点(可自调)
RIGHT = 3000


def fetch_lastest_ranking(mode):
    l, r = 1, RIGHT
    retry_cnt = 0
    ansRanking = None
    while l < r:
        cur_page = (l + r + 1) // 2
        try:
            payload = RankingCrawler._REQUEST_PAYLOAD_TEMPLATE.copy()
            payload['query'] = payload['query'].replace('page: 1', 'page: {}'.format(cur_page))
            resp = requests.post(RankingCrawler.URL,
                                 headers={'Content-type': 'application/json'},
                                 json=payload).json()

            resp = resp['data']['localRanking'] if not GLOBAL else resp['data']['globalRanking']
            # no more data
            if len(resp['rankingNodes']) == 0:
                break
            if not mode:
                top = int(resp['rankingNodes'][0]['currentRating'].split('.')[0])
                if top < RATING:
                    r = cur_page - 1
                else:
                    l = cur_page
                    ansRanking = resp['rankingNodes']
            else:
                top = int(resp['rankingNodes'][0]['currentGlobalRanking'])
                if top > mode:
                    r = cur_page - 1
                else:
                    l = cur_page
                    ansRanking = resp['rankingNodes']

            print('The first contest current rating in page {} is {} .'.format(cur_page, resp['rankingNodes'][0][
                'currentRating']))
            retry_cnt = 0
        except:
            print(f'Failed to retrieved data of page {cur_page}...retry...{retry_cnt}')
            retry_cnt += 1
    ansRanking = ansRanking[::-1]
    last = None
    if not mode:
        while ansRanking and int(ansRanking[-1]['currentRating'].split('.')[0]) >= 1600:
            last = ansRanking.pop()
    else:
        while ansRanking and int(ansRanking[-1]['currentGlobalRanking']) <= mode:
            last = ansRanking.pop()
    return last


class RankingCrawler:
    URL = 'https://leetcode.com/graphql' if GLOBAL else 'https://leetcode-cn.com/graphql'

    _REQUEST_PAYLOAD_TEMPLATE = {
        "operationName": None,
        "variables": {},
        "query":
            r'''{
                    localRanking(page: 1) {
                        totalUsers
                        userPerPage
                        rankingNodes {
                            currentRating
                            currentGlobalRanking
                        }
                    }
                }
                ''' if not GLOBAL else
            r'''{
                    globalRanking(page: 1) {
                        totalUsers
                        userPerPage
                        rankingNodes {
                            currentRating
                            currentGlobalRanking
                        }
                    }
                }
            '''
    }


if __name__ == "__main__":
    crawler = RankingCrawler()
    ans = fetch_lastest_ranking(0)
    n = int(ans['currentGlobalRanking'])
    guardian = fetch_lastest_ranking(int(GUARDIAN * n))
    knight = fetch_lastest_ranking(int(KNIGHT * n))
    if not GLOBAL:
        guardian['currentCNRanking'] = guardian['currentGlobalRanking']
        guardian.pop('currentGlobalRanking')
        knight['currentCNRanking'] = knight['currentGlobalRanking']
        knight.pop('currentGlobalRanking')

    print("Done!")
    print()
    print("目前全{}1600分以上的有{}人".format("球" if GLOBAL else "国", n))
    print("根据这个人数,我们得到的Guardian排名及分数信息为:{}".format(guardian))
    print("根据这个人数,我们得到的Knight排名及分数信息为:{}".format(knight))
    sys.exit()

运行结果

运行结果大致如下:

C:\Users\fengwei\anaconda3\python.exe D:/study_folder/研究生课程/深度学习/my_work/论文分享/leetcode.py
The first contest current rating in page 1501 is 1557 .
The first contest current rating in page 751 is 1676 .
The first contest current rating in page 1126 is 1603 .
The first contest current rating in page 1313 is 1578 .
Failed to retrieved data of page 1219...retry...0
The first contest current rating in page 1219 is 1589 .
The first contest current rating in page 1172 is 1596 .
The first contest current rating in page 1149 is 1599 .
The first contest current rating in page 1137 is 1601 .
The first contest current rating in page 1143 is 1600 .
The first contest current rating in page 1146 is 1599 .
The first contest current rating in page 1144 is 1600 .
The first contest current rating in page 1145 is 1600 .
The first contest current rating in page 1501 is 1557 .
The first contest current rating in page 751 is 1676 .
The first contest current rating in page 376 is 1821 .
The first contest current rating in page 188 is 1978 .
The first contest current rating in page 94 is 2143 .
The first contest current rating in page 47 is 2308 .
The first contest current rating in page 70 is 2216 .
The first contest current rating in page 58 is 2260 .
The first contest current rating in page 64 is 2238 .
The first contest current rating in page 61 is 2249 .
The first contest current rating in page 59 is 2257 .
The first contest current rating in page 1501 is 1557 .
The first contest current rating in page 751 is 1676 .
The first contest current rating in page 376 is 1821 .
The first contest current rating in page 188 is 1978 .
The first contest current rating in page 282 is 1887 .
The first contest current rating in page 329 is 1851 .
The first contest current rating in page 305 is 1870 .
The first contest current rating in page 293 is 1878 .
The first contest current rating in page 287 is 1883 .
The first contest current rating in page 290 is 1881 .
The first contest current rating in page 288 is 1882 .
Done!

目前全国1600分以上的有28612人
根据这个人数,我们得到的Guardian排名及分数信息为:{'currentRating': '2260', 'currentCNRanking': 1430}
根据这个人数,我们得到的Knight排名及分数信息为:{'currentRating': '1883', 'currentCNRanking': 7153}

Process finished with exit code 0

可以看出 1883 以上可以得到 Knight
2260 以上可以得到 Guardian

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Wei *

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值