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

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條評論
主站蜘蛛池模板: 国产一区视频在线免费观看 | 久久免费精品视频在线观看 | 亚洲精品国产精品国自产观看 | 亚洲欧美国产毛片在线 | 男人天堂免费 | 在线观看www. | 国产精品人成福利视频 | 久久五月天综合网 | 亚洲精品视频免费看 | 日日噜噜夜夜狠狠tv视频免费 | 精品久久影院 | 成人免费观看www视频 | 亚洲综合色婷婷 | 国产区一区 | 久热在线视频精品网站 | 国产你懂的 | 欧美日韩久久毛片 | 综合视频网 | 久久综合视频网站 | 亚洲欧美一区二区三区在线播放 | 午夜性色福利视频在线视频 | 中文字幕日韩女同互慰视频 | 久久久国产精品免费看 | 久久亚洲免费视频 | 国产精品视频国产永久视频 | 久久中文字幕亚洲精品最新 | 久草最新在线 | 婷婷国产成人久久精品激情 | 奇米影视777在线播放 | 精品综合网 | 色播综合网 | 92精品国产自产在线观看 | 国产高清精品久久久久久久 | 亚洲四虎永久在线播放 | 日韩 欧美 中文字幕 不卡 | 精品国产三级v | 久久天天躁狠狠躁夜夜呲 | 国产精品伦一区二区三级视频 | 亚州一级| 成人午夜影院在线观看 | 亚洲欧洲精品国产区 |