翻硬幣 第四屆藍橋杯省賽C B組

2021-10-23 01:38:43 字數 1256 閱讀 1912

題目描述

小明正在玩乙個「翻硬幣」的遊戲。

桌上放著排成一排的若干硬幣。我們用 * 表示正面,用 o 表示反面(是小寫字母,不是零)。

比如,可能情形是:**oo***oooo

如果同時翻轉左邊的兩個硬幣,則變為:oooo***oooo

現在小明的問題是:如果已知了初始狀態和要達到的目標狀態,每次只能同時翻轉相鄰的兩個硬幣,那麼對特定的局面,最少要翻動多少次呢?

我們約定:把翻動相鄰的兩個硬幣叫做一步操作。

輸入格式:

兩個等長的字串,分別表示初始狀態和要達到的目標狀態。

輸出格式

乙個整數,表示最小操作步數

資料範圍

輸入字串的長度不超過100

資料保證答案一定有解。

輸入樣例1

**********

o****o****

輸出樣例1

5
輸入樣例2

*o**o***o***

*o***o**o***

輸出樣例2

1
ac**及解釋:

/*

1.開始我想的是暴力列舉,列舉每乙個硬幣是否變化,如果變化,則左邊的也一起變化,最後發現,他的資料的長度是100,那麼我們要做2的99次方的變化,肯定超過時間,果斷放棄

2.這個時候,換乙個方法,當我們變化了硬幣之後,狀態就固定下來,這個時候,只能靠旁邊的硬幣去變化其狀態

*/#include

#include

#include

using

namespace std;

string coin;

//輸入的字串

string resultcoin;

//結果字串

int count =0;

//需要多少次操作

intmain()

} cout << count << endl;

return0;

}

第四屆藍橋杯省賽C B組 翻硬幣

程式輸入 兩行等長的字串,分別表示初始狀態和要達到的目標狀態。每行的長度 1000 程式輸出 乙個整數,表示最小操作步數 例如 使用者輸入 o o 程式應該輸出 5再例如 使用者輸入 o o o o o o 程式應該輸出 1資源約定 峰值記憶體消耗 64m cpu消耗 1000ms 請嚴格按要求輸出...

第四屆藍橋杯 翻硬幣

小明正在玩乙個 翻硬幣 的遊戲。桌上放著排成一排的若干硬幣。我們用 表示正面,用 o 表示反面 是小寫字母,不是零 比如,可能情形是 oo oooo 如果同時翻轉左邊的兩個硬幣,則變為 oooo oooo 現在小明的問題是 如果已知了初始狀態和要達到的目標狀態,每次只能同時翻轉相鄰的兩個硬幣,那麼對...

第四屆藍橋杯 翻硬幣

問題描述 小明正在玩乙個 翻硬幣 的遊戲。桌上放著排成一排的若干硬幣。我們用 表示正面,用 o 表示反面 是小寫字母,不是零 比如,可能情形是 oo oooo,如果同時翻轉左邊的兩個硬幣,則變為 oooo oooo現在小明的問題是 如果已知了初始狀態和要達到的目標狀態,每次只能同時翻轉相鄰的兩個硬幣...