小编qwr*_*qwr的帖子

紧凑的写作方式(a + b == c或a + c == b或b + c == a)

是否有更紧凑或pythonic的方式来编写布尔表达式

a + b == c or a + c == b or b + c == a
Run Code Online (Sandbox Code Playgroud)

我想出来了

a + b + c in (2*a, 2*b, 2*c)
Run Code Online (Sandbox Code Playgroud)

但这有点奇怪.

python boolean

136
推荐指数
10
解决办法
1万
查看次数

删除部分字符串

如何删除部分字符串?例如,ATGAS_1121我想删除之前的所有内容_.

regex string r

79
推荐指数
5
解决办法
20万
查看次数

将正常曲线叠加到R中的直方图

我已经设法在网上找到如何将正常曲线叠加到R中的直方图,但我想保留直方图的正常"频率"y轴.请参阅下面的两个代码段,并注意在第二个代码段中,y轴被替换为"density".如何将y轴保持为"频率",就像在第一个图中一样.

作为奖励:我想在密度曲线上标记SD区域(最多3 SD).我怎样才能做到这一点?我试过了abline,但是这条线延伸到了图形的顶部,看起来很丑陋.

g = d$mydata
hist(g)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

g = d$mydata
m<-mean(g)
std<-sqrt(var(g))
hist(g, density=20, breaks=20, prob=TRUE, 
     xlab="x-variable", ylim=c(0, 2), 
     main="normal curve over histogram")
curve(dnorm(x, mean=m, sd=std), 
      col="darkblue", lwd=2, add=TRUE, yaxt="n")
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

看看上面的图像中,y轴是"密度".我想把它变成"频率".

plot r gaussian histogram

58
推荐指数
3
解决办法
17万
查看次数

为什么 C++20 的 `std::popcount` 仅限于无符号类型?

P0553R4中的功能:位运算仅限于无符号整数。该提案没有给出这一限制的理由。我可以看到,如果没有定义有符号整数的位表示,这是有意义的,但使用 C++20,我们可以保证有符号整数使用二进制补码。

对我来说,允许使用有符号整数类型调用eg似乎是合理的std::popcount,因为实现可以简单地转换为相应的无符号类型以在无符号域中执行位操作。

P0553R4添加这个约束的原因是什么?(只是 P0553R4 和 P0907R4 之间缺少同步吗?)

c++ language-design language-lawyer c++20

41
推荐指数
2
解决办法
4990
查看次数

grequest异步的方式是什么?

我一直在使用python请求库,最近需要异步发出请求,这意味着我想发送HTTP请求,让我的主线程继续执行,并在调用时调用请求返回.

当然,我是通往grequests库(https://github.com/kennethreitz/grequests),但我对这种行为感到困惑.例如:

import grequests

def print_res(res):
    from pprint import pprint
    pprint (vars(res))

req = grequests.get('http://www.codehenge.net/blog', hooks=dict(response=print_res))
res = grequests.map([req])

for i in range(10):
    print i
Run Code Online (Sandbox Code Playgroud)

上面的代码将产生以下输出:

<...large HTTP response output...>

0
1
2
3
4
5
6
7
8
9
Run Code Online (Sandbox Code Playgroud)

grequests.map()调用显然会阻塞,直到HTTP响应可用.我似乎错误地理解了这里的"异步"行为,而grequest库只是用于同时执行多个HTTP请求并将所有响应发送到单个回调.这准确吗?

python gevent python-requests grequests

39
推荐指数
2
解决办法
3万
查看次数

这个没有 libc 的 C 程序如何工作?

我遇到了一个没有 libc 的最小 HTTP 服务器:https : //github.com/Francesco149/nolibc-httpd

我可以看到定义了基本的字符串处理函数,导致write系统调用:

#define fprint(fd, s) write(fd, s, strlen(s))
#define fprintn(fd, s, n) write(fd, s, n)
#define fprintl(fd, s) fprintn(fd, s, sizeof(s) - 1)
#define fprintln(fd, s) fprintl(fd, s "\n")
#define print(s) fprint(1, s)
#define printn(s, n) fprintn(1, s, n)
#define printl(s) fprintl(1, s)
#define println(s) fprintln(1, s)
Run Code Online (Sandbox Code Playgroud)

基本的系统调用在 C 文件中声明:

size_t read(int fd, void *buf, size_t nbyte);
ssize_t write(int fd, const void *buf, size_t nbyte);
int open(const char *path, int flags); …
Run Code Online (Sandbox Code Playgroud)

c assembly x86-64 system-calls abi

27
推荐指数
2
解决办法
1634
查看次数

从具有重叠的池中挑选无序组合

我有值池,我想通过从某些池中挑选来生成所有可能的无序组合.

例如,我想从池0,池0和池1中选择:

>>> pools = [[1, 2, 3], [2, 3, 4], [3, 4, 5]]
>>> part = (0, 0, 1)
>>> list(product(*(pools[i] for i in part)))
[(1, 1, 2), (1, 1, 3), (1, 1, 4), (1, 2, 2), (1, 2, 3), (1, 2, 4), (1, 3, 2), (1, 3, 3), (1, 3, 4), (2, 1, 2), (2, 1, 3), (2, 1, 4), (2, 2, 2), (2, 2, 3), (2, 2, 4), (2, 3, 2), (2, 3, 3), (2, 3, 4), …
Run Code Online (Sandbox Code Playgroud)

python combinations combinatorics

25
推荐指数
5
解决办法
794
查看次数

有没有更好的方法在JavaScript中对数组项进行部分求和?

我想知道是否有更好的方法可以为数组的部分和生成更好的性能的解决方案。

给定一个说的数组x = [ 0, 1, 2, 3, 4, 5 ],我生成了项目的子数组,然后计算了每个数组的总和,得出:

[ 0, 1, 3, 6, 10, 15 ]
Run Code Online (Sandbox Code Playgroud)

因此,完整的代码是:

x.map((y,i)=>x.filter((t,j)=>j<=i))
 .map(ii=>ii.reduce((x,y)=>x+y,0))
Run Code Online (Sandbox Code Playgroud)

我想知道平面图或其他数组方法是否具有不需要扩展每个子数组的解决方案。

javascript arrays functional-programming prefix-sum

25
推荐指数
6
解决办法
1924
查看次数

Chudnovsky二元分裂和分解

本文中,给出了使用二进制分裂的Chudnovsky pi公式的快速递归公式.在python中:

C = 640320
C3_OVER_24 = C**3 // 24
def bs(a, b):
    if b - a == 1:
        if a == 0:
            Pab = Qab = 1
        else:
            Pab = (6*a-5)*(2*a-1)*(6*a-1)
            Qab = a*a*a*C3_OVER_24
        Tab = Pab * (13591409 + 545140134*a) # a(a) * p(a)
        if a & 1:
            Tab = -Tab
    else:
        m = (a + b) // 2
        Pam, Qam, Tam = bs(a, m)
        Pmb, Qmb, Tmb = bs(m, b)

        Pab = Pam * Pmb …
Run Code Online (Sandbox Code Playgroud)

c recursion pi gmp factoring

22
推荐指数
2
解决办法
703
查看次数

如何在Python中使用sha256哈希

我想读一个密码文件.然后我尝试计算每个密码的哈希值,并将其与我已经拥有的哈希值进行比较,以确定我是否发现了密码.但是我不断得到的错误消息是"TypeError:必须在散列之前对Unicode对象进行编码".这是我的代码:

from hashlib import sha256

with open('words','r') as f:
    for line in f:

        hashedWord = sha256(line.rstrip()).hexdigest()

        if hashedWord == 'ca52258a43795ab5c89513f9984b8f3d3d0aa61fb7792ecefe8d90010ee39f2':
            print(line + "is one of the words!")
Run Code Online (Sandbox Code Playgroud)

有人可以帮忙并提供解释吗?

python sha256

15
推荐指数
2
解决办法
3万
查看次数