主頁 >  其他 > SCAU2021春季個人排位賽第七場 (部分題解))

SCAU2021春季個人排位賽第七場 (部分題解))

2021-05-07 09:12:45 其他

A:折半搜索+二分 跟上星期一樣的知識點
B:拓撲排序
C:里面知識點都經常考并且糅合在一起,非常好的一道題,并查集+樹DP考慮邊的貢獻
D:掃描線 上星期知識點 出這道題是因為可以用bitset暴力卡,可以學習bitset,但是記得補正解
E:思維題 拿來簽到
F:弗洛伊德
G:高斯消元比較模板的題,但是很惡心,卡精度,卡eps不能調太大,而且卡long double

A題

CodeForces - 912E

Opposite to Grisha's nice behavior, Oleg, though he has an entire year at his disposal, didn't manage to learn how to solve number theory problems in the past year. That's why instead of Ded Moroz he was visited by his teammate Andrew, who solemnly presented him with a set of n distinct prime numbers alongside with a simple task: Oleg is to find the k-th smallest integer, such that all its prime divisors are in this set.

Input

The first line contains a single integer n (1?≤?n?≤?16).

The next line lists n distinct prime numbers p1,?p2,?...,?pn (2?≤?pi?≤?100) in ascending order.

The last line gives a single integer k (1?≤?k). It is guaranteed that the k-th smallest integer such that all its prime divisors are in this set does not exceed 1018.

Output

Print a single line featuring the k-th smallest integer. It's guaranteed that the answer doesn't exceed 1018.

Examples

Input

3
2 3 5
7

Output

8

Input

5
3 7 11 13 31
17

Output

93

Note

The list of numbers with all prime divisors inside {2,?3,?5} begins as follows:

(1,?2,?3,?4,?5,?6,?8,?...)

The seventh number in this list (1-indexed) is eight.

知識點和上星期一樣,折半搜索+二分查找,

主要是一開始讀不懂題,根本不知道是什么意思,試了好久才知道是包括1且因數要包括集合內的元素,

先用DFS列舉好所有狀態的結果,然后兩邊雙指標同時進行,二分列舉目前的mid是排在第幾,直到找到ans為止,

代碼:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <stdlib.h>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stack>
#include <queue>
#include <list>
#include <vector>

using namespace std;

const long long oo=1e18;
int k;
int n; 
long long p[20];
vector<long long> a[2];
void ready()
{
    ios::sync_with_stdio(false),cin.tie(0);
    cin>>n;
    for(int i=1;i<=n;i++)
        cin>>p[i];
    cin>>k;
}

void dfs(int temp,int u,long long now)
{
	a[temp].push_back(now);
	for(int i=u;i<=n;i+=2)
	  if(oo/p[i]>=now)
	    dfs(temp,i,now*p[i]);
}

bool check(long long mid)
{
	long long ki=0;
	for(int i=(int)a[0].size()-1,j=0;i>=0;i--)
	{
		while(j<(int)a[1].size() && a[1][j]<=mid/a[0][i])
	      j++;
		ki+=j;
	}
	return ki>=k;
}

void work()
{
    dfs(0,1,1);
	dfs(1,2,1);
	sort(a[0].begin(),a[0].end());
	sort(a[1].begin(),a[1].end());
	long long l=1,r=oo,mid=(l+r)/2;
	while(l<=r)
	{
		mid=(l+r)/2;
		if(check(mid))
		  r=mid-1;
		else
		  l=mid+1;
	}
	cout<<l;
	return ;
}

int main()
{
    ready();
    work();
    return 0;
}

B題

CodeForces - 770C

Now you can take online courses in the Berland State University! Polycarp needs to pass k main online courses of his specialty to get a diploma. In total n courses are availiable for the passage.

The situation is complicated by the dependence of online courses, for each course there is a list of those that must be passed before starting this online course (the list can be empty, it means that there is no limitation).

Help Polycarp to pass the least number of courses in total to get the specialty (it means to pass all main and necessary courses). Write a program which prints the order of courses.

Polycarp passes courses consistently, he starts the next course when he finishes the previous one. Each course can't be passed more than once.

Input

The first line contains n and k (1?≤?k?≤?n?≤?105) — the number of online-courses and the number of main courses of Polycarp's specialty.

The second line contains k distinct integers from 1 to n — numbers of main online-courses of Polycarp's specialty.

Then n lines follow, each of them describes the next course: the i-th of them corresponds to the course i. Each line starts from the integer ti (0?≤?ti?≤?n?-?1) — the number of courses on which the i-th depends. Then there follows the sequence of ti distinct integers from 1 to n — numbers of courses in random order, on which the i-th depends. It is guaranteed that no course can depend on itself.

It is guaranteed that the sum of all values ti doesn't exceed 105.

Output

Print -1, if there is no the way to get a specialty.

Otherwise, in the first line print the integer m — the minimum number of online-courses which it is necessary to pass to get a specialty. In the second line print m distinct integers — numbers of courses which it is necessary to pass in the chronological order of their passage. If there are several answers it is allowed to print any of them.

Examples

Input

6 2
5 3
0
0
0
2 2 1
1 4
1 5

Output

5
1 2 3 4 5 

Input

9 3
3 9 5
0
0
3 9 4 5
0
0
1 8
1 6
1 2
2 1 2

Output

6
1 2 9 4 5 3 

Input

3 3
1 2 3
1 2
1 3
1 1

Output

-1

Note

In the first test firstly you can take courses number 1 and 2, after that you can take the course number 4, then you can take the course number 5, which is the main. After that you have to take only the course number 3, which is the last not passed main course.

雖說是拓撲排序,但我感覺更像是思維DFS,主要在記錄狀態的時候注意一下,好吧就是記錄狀態這里要做好就行了,就是個普普通通的DFS,

保存狀態和最后存進ans在DFS最后儲存,這樣能保證先儲存的就是最里面的點,這個地方卡了我好久,比賽的時候就是卡在這個地方了,

注意要反方向構圖!

代碼:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <stdlib.h>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stack>
#include <queue>
#include <list>
#include <vector>
 
using namespace std;
 
int n,k;
int p[100005],nex[100005],to[100005],pi;
int ki[100005];
int ans[100005],ansi;
bool q[100005];
int f[100005];
int cnt[100005];
bool ANS;
struct B{
    int id;
    int in_;
}t[100005];
 
 
void read_in(int u,int v)
{
    pi++;nex[pi]=p[u];p[u]=pi;to[pi]=v;
}
 
bool cmp(B i,B j)
{
    return i.in_<j.in_;
}
 
void ready()
{
    ios::sync_with_stdio(false),cin.tie(0);
    cin>>n>>k;
    for(int i=1;i<=k;i++)
      cin>>ki[i];
    for(int i=1;i<=n;i++)
    {
        int ti;
        cin>>ti;
        while(ti--)
        {
            int vi;
            cin>>vi;
            read_in(i,vi);
        }
    }

}
 
void dfs(int u)
{
    f[u]=-1;
    for(int i=p[u],v=to[i];i;i=nex[i],v=to[i])
    {
    	if(f[v]==-1)
    	{
    		ANS=true;
    		return ;
		}
		
		if(!f[v])
		  dfs(v);
	}
	f[u]=1;
	ans[++ansi]=u;
}
 
void work()
{
    for(int i=1;i<=k;i++)
    {
        if(!f[ki[i]])
        dfs(ki[i]);        
		if(ANS)
        {
            cout<<-1;
            return ;
        }
    }
    cout<<ansi<<'\n';
    for(int i=1;i<=ansi;i++)
        cout<<ans[i]<<' ';
    return ;
}
 
int main()
{
    ready();
    work();
    return 0;
}
/*
5 3
2 1  3
0
1 1
1 2
0
0
*/

E題

CodeForces - 1186C

Vus the Cossack has two binary strings, that is, strings that consist only of "0" and "1". We call these strings aa and bb. It is known that |b|≤|a||b|≤|a|, that is, the length of bb is at most the length of aa.

The Cossack considers every substring of length |b||b| in string aa. Let's call this substring cc. He matches the corresponding characters in bb and cc, after which he counts the number of positions where the two strings are different. We call this function f(b,c)f(b,c).

For example, let b=00110b=00110, and c=11000c=11000. In these strings, the first, second, third and fourth positions are different.

Vus the Cossack counts the number of such substrings cc such that f(b,c)f(b,c) is even.

For example, let a=01100010a=01100010 and b=00110b=00110. aa has four substrings of the length |b||b|: 0110001100, 1100011000, 1000110001, 0001000010.

  • f(00110,01100)=2f(00110,01100)=2;
  • f(00110,11000)=4f(00110,11000)=4;
  • f(00110,10001)=4f(00110,10001)=4;
  • f(00110,00010)=1f(00110,00010)=1.

Since in three substrings, f(b,c)f(b,c) is even, the answer is 33.

Vus can not find the answer for big strings. That is why he is asking you to help him.

Input

The first line contains a binary string aa (1≤|a|≤1061≤|a|≤106) — the first string.

The second line contains a binary string bb (1≤|b|≤|a|1≤|b|≤|a|) — the second string.

Output

Print one number — the answer.

Examples

Input

01100010
00110

Output

3

Input

1010111110
0110

Output

4

Note

The first example is explained in the legend.

In the second example, there are five substrings that satisfy us: 10101010, 01010101, 11111111, 11111111.

思維題,吃在了看不懂題的虧,不知道even是偶數的意思,也沒去猜f(b,c)到底是什么意思,

題意也就是兩串01組成的字串a,b,|a| >= |b| ,在a中取 |b| 長度,和b異或后如果1的個數為偶數則這是一個目標子串,問a中有多少個長度為|b|且滿足條件的子串,

思維題,找規律,7爺比完之后立刻和我說這肯定cf的題目,

如果兩個子串中,1的個數同為偶數或者同為奇數,則不管1在不在同一個位置,異或之后剩下的1肯定都是偶數,所以用前綴和維護就好,

代碼

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <stdlib.h>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stack>
#include <queue>
#include <list>
#include <vector>

using namespace std;

string a,b;
int la,lb,ai[1000006],bi[1000006],ans;
void ready()
{
    ios::sync_with_stdio(false),cin.tie(0);
	cin>>a>>b;
	la=a.size();lb=b.size();
	for(int i=0;i<la;i++)
	  if(i==0)
	    ai[i]=a[i]-'0';
	  else
	    ai[i]=ai[i-1]+a[i]-'0';
	for(int i=0;i<lb;i++)
	  if(i==0)
	    bi[i]=b[i]-'0';
	  else
	    bi[i]=bi[i-1]+b[i]-'0';
}

int check_(int x,int y)
{
	if(x%2==y%2)
	  return 1;
	else
	  return 0;
}

int main()
{
    ready();
    for(int i=lb-1;i<la;i++)
    {
    	if(i==lb-1)
    	  ans+=check_(bi[lb-1],ai[i]);
    	else
    	  ans+=check_(bi[lb-1],ai[i]-ai[i-lb]);
	}
	cout<<ans;
    return 0;
}

F題

CodeForces - 33B

Boy Valera likes strings. And even more he likes them, when they are identical. That's why in his spare time Valera plays the following game. He takes any two strings, consisting of lower case Latin letters, and tries to make them identical. According to the game rules, with each move Valera can change one arbitrary character Ai in one of the strings into arbitrary character Bi, but he has to pay for every move a particular sum of money, equal to Wi. He is allowed to make as many moves as he needs. Since Valera is a very economical boy and never wastes his money, he asked you, an experienced programmer, to help him answer the question: what minimum amount of money should Valera have to get identical strings.

Input

The first input line contains two initial non-empty strings s and t, consisting of lower case Latin letters. The length of each string doesn't exceed 105. The following line contains integer n (0?≤?n?≤?500) — amount of possible changings. Then follow n lines, each containing characters Ai and Bi (lower case Latin letters) and integer Wi (0?≤?Wi?≤?100), saying that it's allowed to change character Ai into character Bi in any of the strings and spend sum of money Wi.

Output

If the answer exists, output the answer to the problem, and the resulting string. Otherwise output -1 in the only line. If the answer is not unique, output any.

Examples

Input

uayd
uxxd
3
a x 8
x y 13
d c 3

Output

21
uxyd

Input

a
b
3
a b 2
a b 3
b a 5

Output

2
b

Input

abc
ab
6
a b 4
a b 7
b a 8
c b 11
c a 3
a c 0

Output

-1

題意:有n種替換字母的方式,將兩個只包括小寫字母的字串替換成相同字串所需要的最少錢是多少,結果字串是什么,

一開始以為直接逐位比較變成對方就OK了,然后發現可能可以同時變為第三個字母,然后加了個跳板一起變成第三個,然后想想,可以構造一個圖,用Floyd來做,兩個字母之間有轉換也就是有路,費用就是權值,Floyd就能找到兩個之間轉換到哪個字母比較好,花錢比較少,后面就簡單了,

代碼:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <stdlib.h>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stack>
#include <queue>
#include <list>
#include <vector>

using namespace std;

string a,b;
long long val[30][30];
int len_a,len_b,n;
long long money;
char ans[100005];

void ready()
{
    ios::sync_with_stdio(false),cin.tie(0);
    cin>>a>>b>>n;
    len_a=a.size();
    len_b=b.size();
    for(int i=1;i<=26;i++)
        for(int j=1;j<=26;j++)
          val[i][j]=1000000000;
    for(int i=1;i<=n;i++)
    {
        char x,y;
        long long v;
        cin>>x>>y>>v;
        val[x-'a'+1][y-'a'+1]=min(val[x-'a'+1][y-'a'+1],v);
    }
    for(int i=1;i<=26;i++)
        val[i][i]=0;
    for(int k=1;k<=26;k++)
        for(int i=1;i<=26;i++)
          for(int j=1;j<=26;j++)
            val[i][j]=min(val[i][j],val[i][k]+val[k][j]);
}

bool work()
{

    if(len_a!=len_b)
        return false;
    for(int i=0;i<len_a;i++)
    {
        if(a[i]!=b[i])
        {
            long long cost=1000000000,ci;
            int ai=a[i]-'a'+1;
            int bi=b[i]-'a'+1;
            for(int j=1;j<=26;j++)
            {
                if(val[ai][j]+val[bi][j]<cost)
                {
                    cost=val[ai][j]+val[bi][j];
                    ci=j;
                }
            }
            if(cost==1000000000)
                return false;
            money+=cost;
            ans[i]=char('a'+ci-1);
        }
        else
        {
            ans[i]=a[i];
        }
    }
    cout<<money<<'\n';
    for(int i=0;i<len_a;i++)
        cout<<ans[i];
    return true;
}

int main()
{
    ready();
    if(!work())
        cout<<-1;
    return 0;
}

G題

Gym - 100962A

Problem A. ABBA Input file: standard input Output file: standard output Time limit: 1 second Memory limit: 256 mebibytes In this problem, we operate with tables of fixed size h × w consisting of real values. Let’s define an addition operation on two tables as their component-wise sum. A multiplication table for two real vectors α = (α1, α2, . . . , αh) and β = (β1, β2 . . . , βw) is the table Tα,β where the element at the intersection of i-th row and j-th column is αi · βj . You start with a table of size h × w consisting of zeroes. In one turn, you are allowed to add a multiplication table for two arbitrary real vectors α of length h and β of length w to the current table. Your task is to make the current table equal to a goal table G in the minimum number of turns. What is the minimum number of turns you have to perform? Input The first line of input contains two integers h and w (1 ≤ h, w ≤ 200). The i-th of the following h lines contain w space-separated integers ai,1, ai,2, . . . , ai,w (?106 ≤ ai,j ≤ 106 ), where ai,j is the value on the intersection of i-th row and j-th column of the goal table G. Output If it’s impossible to obtain the goal table G, print “-1” (without the quotes). Otherwise, output the minimum number of turns you have to perform in order to achieve it. Examples standard input standard output 3 5 1 2 3 4 5 2 4 6 8 10 3 6 9 12 15 1 3 3 2 0 2 0 2 0 2 0 2 2 Note In the first sample, the table T can be obtained using α = ( 1 2 3) , β = ( 1 2 3 4 5) . In the second sample, the table T can be obtained as sum of Tα1,β1 = ? ? 1 1 1 1 1 1 1 1 1 ? ? for vectors α1 = ( 1 1 1) , β1 = ( 1 1 1) and Tα2,β2 = ? ? 1 ?1 1 ?1 1 ?1 1 ?1 1 ? ? for vectors α2 = ( ?1 1 ?1 ) , β2 = ( ?1 1 ?1 )

題意:求矩陣的秩,

身為一個數學與應用數學專業的學生,高等代數上學期也學了,高斯消元法求矩陣的秩也是我們平常的做法,上學期高代學得不錯,專業第5,但是這道題看不懂題根本不知道再求秩......

而且以前不敢寫高斯消元法的代碼就是怕經度問題,現在打出來了,剛剛好可以用行程式設計的課程設計里,nice!

高斯消元法,也就是湊1消去后面的項,直到形成上三角矩陣,

代碼:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <stdlib.h>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stack>
#include <queue>
#include <list>
#include <vector>

using namespace std;

const long double ep=1e-2;
long double a[205][205];
int r,c;  

void ready()
{
    ios::sync_with_stdio(false),cin.tie(0);
	cin>>r>>c;
	for(int i=1;i<=r;i++)
	  for(int j=1;j<=c;j++)
	    cin>>a[i][j]; 
}

void work()
{
	int row=1,col=1;
	for( ;row<=r && col<=c;row++,col++)
	{
		int max_r=row;
		for(int i=row+1;i<=r;i++)
		  if(abs(a[i][col])>abs(a[max_r][col]))
		    max_r=i;
		if(max_r!=row)
		  for(int i=row;i<=c;i++)
		    swap(a[row][i],a[max_r][i]); 
		if(abs(a[row][col])<ep)
		{
			row--; 
			continue;
		}
		for(int i=row+1;i<=r;i++)
		  if(abs(a[i][col])>ep)
		  {
		  	double t=a[i][col]/a[row][col];
		  	for(int j=row;j<=c;j++)
		  	  a[i][j]-=t*a[row][j];
		  }
	}
	cout<<row-1;

}

int main()
{
    ready();
    work();
    return 0;
}

好好學英語,下次帶字典去了,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/283184.html

標籤:其他

上一篇:原來Linux大神都是這么記住命令的,看看你們的方法是否一樣。

下一篇:不知道何時,我逐漸喪失了表達能力

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more