亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

uva 10069 Distinct Subsequences(高精度 + DP

系統 1961 0

題目連接:10069 - Distinct Subsequences


題目大意:給出兩個字符串x (lenth < 10000), z (lenth < 100), 求在x中有多少個z。


解題思路:二維數組DP, 有類似于求解最長公共子序列, cnt[i][j]表示在x的前j個字符中有多少個z 前i個字符。

狀態轉移方程 ?

1、x[j] != z[i] ? ? ? ? ? ? ?cnt[i][j] = cnt[i][j - 1];

2、x[j] == z[i] ? cnt[i][j] = cnt[i][j - 1] + cnt[i - 1][j - 1];

計算的時候使用高精度, 并且要見j == 0的情況歸1, i == 0 的情況歸0。


?

    #include <stdio.h>

#include <string.h>

#include <iostream>

using namespace std;

const int N = 10005;

const int M = 105;



struct bign {

    int len, sex;

    int s[M];



    bign() {

	this -> len = 1;

	this -> sex = 0;

	memset(s, 0, sizeof(s));

    }



    bign operator = (const char *number) {

	int begin = 0;

	len = 0;

	sex = 1;

	if (number[begin] == '-') {

	    sex = -1;

	    begin++;

	}

	else if (number[begin] == '+')

	    begin++;



	for (int j = begin; number[j]; j++)

	    s[len++] = number[j] - '0';

    }



    bign operator = (int number) {

	char string[N];

	sprintf(string, "%d", number);

	*this = string;

	return *this;

    }



    bign (int number) {*this = number;}

    bign (const char* number) {*this = number;}



    bign change(bign cur) {

	bign now;

	now = cur;

	for (int i = 0; i < cur.len; i++)

	    now.s[i] = cur.s[cur.len - i - 1];

	return now;

    }



    void delZore() {	// 刪除前導0.

	bign now = change(*this);

	while (now.s[now.len - 1] == 0 && now.len > 1) {

	    now.len--;

	}

	*this = change(now);

    }



    void put() {    // 輸出數值。

	delZore();

	if (sex < 0 && (len != 1 || s[0] != 0))

	    cout << "-";

	for (int i = 0; i < len; i++)

	    cout << s[i];

    }



    bign operator + (const bign &cur){  

	bign sum, a, b;  

	sum.len = 0;

	a = a.change(*this);

	b = b.change(cur);



	for (int i = 0, g = 0; g || i < a.len || i < b.len; i++){  

	    int x = g;  

	    if (i < a.len) x += a.s[i];  

	    if (i < b.len) x += b.s[i];  

	    sum.s[sum.len++] = x % 10;  

	    g = x / 10;  

	}  

	return sum.change(sum);  

    } 

};



bign cnt[M][N], sum;

char x[N], z[M];



int main() {

    int cas;

    scanf("%d", &cas);

    while (cas--) {

	scanf("%s%s", x, z);

	int n = strlen(x), m = strlen(z);

	for (int i = 0; i <= n; i++)

	    cnt[0][i] = 1;



	for (int i = 1; i <= m; i++) {

	    cnt[i][0] = 0;

	    for (int j = 1; j <= n; j++) {

		cnt[i][j] = cnt[i][j - 1];

		if (z[i - 1] == x[j - 1])   

		    cnt[i][j] = cnt[i][j] + cnt[i - 1][j - 1];

	    }

	}

	cnt[m][n].put();

	printf("\n");

    }

    return 0;

}


  


?

?

uva 10069 Distinct Subsequences(高精度 + DP求解子串個數)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美欧美aaaaa一级毛片 | 大杳焦伊人久久综合热 | 激情婷婷成人亚洲综合 | 深夜影院在线观看 | 国产在线91 | 国产丶欧美丶日韩丶不卡影视 | 婷婷自拍 | 岛国片欧美一级毛片 | 天堂日韩 | 91最新入口 | 91在线 | 欧美: | 一区二区三区欧美日韩国产 | 在线亚洲欧洲福利视频 | 视频免费1区二区三区 | 一区二区三区在线 | 日本 | 激情综合视频 | 国产成人一区在线播放 | 护士一级毛片 | 四虎网站 | 一区二区在线不卡 | 欧美一级级a在线观看 | 新久草在线 | 亚洲在线网站 | 久久草视频在线 | 久久精品国产亚洲麻豆 | 欧美一级录像 | 国内精品免费网站牛牛 | 亚洲成精品动漫久久精久 | 亚洲精品国产一区二区三 | 羞羞网页 | 黄色片网站在线观看 | 亚洲精品久久久久中文 | 国产视频久久久 | 日韩亚洲人成在线综合 | 亚洲国产成人私人影院 | 手机看福利片 | 日韩精品免费一级视频 | 国产精品午夜波多野结衣性色 | 青青影院在线观看 | 国产目拍亚洲精品一区二区三区 | 大色佬视频在线观看 |