为了巩固我的基础,准备来做一个博客系统来沉淀一下。
前端 Next.js , tailwindcss
ui figma
后端 Hertz
数据库 mysql
今日进度:
前端立项,后端立项,ui开始设计,xmind设计需求。一切都在朝好的方向发展!
为了巩固我的基础,准备来做一个博客系统来沉淀一下。
前端 Next.js , tailwindcss
ui figma
后端 Hertz
数据库 mysql
今日进度:
前端立项,后端立项,ui开始设计,xmind设计需求。一切都在朝好的方向发展!
Cobra 是go语言中用于创建 CLI 应用程序的库。
本身提供了一个快速创建 cli 应用的脚手架 cobra-cli
go get -u github.com/spf13/cobra@latest
go install github.com/spf13/cobra-cli@latest
现在假设要创建一个名为test的cli程序,你可以使用一下步骤来创建
go mod init test
cobra-cli init
--author
:
cobra-cli init --author "Steve Francia [email protected]"
--license
:
cobra-cli init --license apache
--viper
:
cobra-cli init --viper
使用 --viper
标志自动设置 viper
Viper 是 Cobra 的伴侣,旨在轻松处理环境变量和配置文件,并将它们无缝连接到应用程序标志。
这个部分使用cobra-cli的add命令,例如:
cobra-cli add serve
cobra-cli add config
cobra-cli add create -p 'configCmd'
您会注意到,此最终命令具有-p
标志。这用于将父命令分配给新添加的命令。在这种情况下,我们想将 “create” 命令分配给 “config” 命令。如果未指定,则所有命令的默认父级为 rootCmd。
默认情况下,cobra-cli
会将Cmd
附加到提供的名称,并将此名称用作内部变量名称。指定父级时,请确保与代码中使用的变量名称匹配。
注意:命令名称使用 camelCase(而不是 snake_case/kebab-case)。否则,您将遇到错误。例如,cobra-cli add add-user
不正确,但cobra-cli add addUser
有效。
最终在运行完这三个命令之后会在 cmd
文件夹中看到对应命令的go文件。这时可以参考官方文档来进行编写对应的代码。
参考:
最近在去听某个做软件开发的团队介绍平时的工作流程的时候,有讲到一个做思维导图的软件,是叫做xmind。我打算最近学习使用这个软件。看起来,感觉做的很漂亮,这个软件。
url: https://ybt.ssoier.cn/problem_show.php?pid=1638
tag:
裴蜀定理,拓展欧几里得算法,数论
思路:
根据题意可以得出,y - x = b d mod n ⇒ b d - a n = y - x。所以可以先求出n与d的最大公约数,如果y - x 不能整除,说明不能到达,如果可以整除再求最小的b。用拓展欧几里得算法可以求出 x n + y d = (n,d) 的一组解,然后令该式两边同乘 (y - x)/ (n,d)可以将该式变为b d - a * n = y - x。最后求最小的d就是让其取模n / gcd的正余数。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long LL;
LL exgcd(LL a, LL b, LL &x, LL &y)
{
if (!b)
{
x = 1, y = 0;
return a;
}
LL d = exgcd(b, a % b, y, x);
y -= a / b * x;
return d;
}
int main()
{
int T;
cin >> T;
while (T --)
{
LL n, d, x, y, a, b;
scanf("%lld%lld%lld%lld", &n, &d, &x, &y);
LL gcd = exgcd(n, d, a, b);
if ((y - x) % gcd) cout << "Impossible\n";
else
{
b *= (y - x) / gcd;
n /= gcd;
printf("%lld\n", (b % n + n) % n);
}
}
return 0;
}
url: http://oj.ecustacm.cn/problem.php?id=1369
tag:
模拟
思路:
求字节的二进制表示,其实就是求每个数的补码。对于正数来说,补码就是原码。对于负数来说,先是对原码求反码然后再加1.对于-128来说比较特殊,补码是10000000,通过正常的求法求不出,所以需要特殊判断。
代码:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
int num[10];
void resoult(int a)
{
int j = 8;
while(a)
{
num[j --] = a % 2;
a /= 2;
}
}
void inverse()
{
for (int i = 2; i <= 8; i ++)
{
if (num[i] == 0) num[i] = 1;
else num[i] = 0;
}
num[8] += 1;
for (int i = 8; i >= 3; i --)
{
num[i - 1] += num[i] / 2;
num[i] %= 2;
}
}
void binary(int a)
{
if (a == -128)
{
cout << "1 " << endl;
return;
}
memset(num, 0, sizeof num);
if (a >= 0)
{
num[1] = 0;
resoult(a);
}
else
{
num[1] = 1;
resoult(abs(a));
inverse();
}
}
void print()
{
for (int i = 1; i <= 8; i ++)
{
if (num[i]) cout << 1;
else cout << ' ';
}
}
int main()
{
for (int i = 0; i < 10; i ++)
{
for (int j = 0; j < 16; j ++)
{
int a, b;
cin >> a >> b;
binary(a);
print();
binary(b);
print();
cout << endl;
}
cout << endl;
}
return 0;
}
简洁版:
#include <iostream>
#include<cstring>
using namespace std;
int num[10];
void print()
{
for(int i=1;i<=8;i++) printf("%c",num[i]==1?"1":" ");
}
int main()
{
int a,b;
for(int i=1;i<=10;i++)
{
for(int j=1;j<=16;j++)
{
cin>>a>>b;
memset(num,0,sizeof(num ));
for(int k =8;k>=1;i--) num[k]&=a,a>>=1;
print();
memset(num,0,sizeof(num ));
for(int k =8;k>=1;k--) num[k]&=b,b>>=1;
print();
cout<<endl;
}
cout<<endl;
}
return 0;
}
结果:
1
1
1 1
111111111111
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1 1
1 1 1
1 1111
11
1 1
1 1
1 1 1 1
1111111 111111
1 1 1 1
1 11 1
1 1 1
1 1 1 1
111111 11 1
1 1 1 1
1 1 1
1 1 1
1 1 1
111111 1
1 1 1 1
1
1
1
1
1 1
111111111111
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1 1
1 1 1
1 1111
11
1
1 1
1
11 1
11
1 1 1
1111111
1 1
1 1 1
1 1
1 1
111 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 111
1 1 1
1
11
1
1
111111111111111
1
1 1
11111111
1 1
1 1
1 1
1 1
1 1
1 1
1 1 1
1 1
1 1
1 1 1 1
11111 111111
1 1 1 1
1 1 1
1
11111111111
1
111111111111111
1
1 1
11111111111
1 1
1 1
1 1
1
1
11111111111
1
1
1
1 1
111111111111111
1
1
1
1
1
1
1
1 1
1
1
1
1111111
1 1
11 1
1 1 11
1 1 1
1 1
1
11 1
11
111 1111111
1 1
11 1
1 1 1
1 111
1
111
111
1
1
1
1 1 1
1 1 1
1 1 11
1 1 1
1 1 1
1 1 1
1 1
1 1
1
1
1
11
111
1111111
11 11
11 11
111 11
111
111
11
1
11
1
1111
11
1
答案:
#include <iostream>
#include <cmath>
#include <cstdio>
using namespace std;
int main()
{
printf("%.0f", pow(9, 9));
return 0;
}