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

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條評論
主站蜘蛛池模板: 在线观看麻豆国产精品 | 老司机永久免费网站在线观看 | 久草精彩视频 | 久草视频在线免费播放 | 国产精品一区二区三区四区五区 | 久久爱综合网 | 免费香蕉依人在线视频久 | 国内精品久久久久影院中国 | 49xxx中国妇女内谢视频 | 丁香婷婷网 | 青草资源站 | 高清亚洲 | 中文字幕免费在线观看 | 日韩欧美a级高清毛片 | 写真福利 第 页 在线视频 | 狠狠噜噜 | 激情午夜婷婷 | 精品哟哟国产在线观看 | 香蕉网伊在线中文慕大全 | 在线观看一级毛片 | 日本久久网| 中文字幕在线免费看 | 一本久久a久久精品vr综合 | 操你妹影院 | 精品国产91久久久久久久a | 九九视频在线观看视频23 | www.97影院| 久久亚洲精品一区二区三区浴池 | 91中文字幕在线视频 | 国产精品深爱在线 | 国产第六页 | 成人久久18网站 | 国产精品久久久久久久久久久威 | a级亚洲片精品久久久久久久 | 普通话对白国产情侣自啪 | 四虎影视网站 | 中文字幕第66页永久乱码 | 交专区videossex另类 | 91精品国产综合久久福利 | 男人的天堂免费视频 | 图片专区亚洲 欧美 另类 |