藍橋杯 數字密碼發生器 取餘

2021-06-29 08:00:54 字數 1291 閱讀 6334

在對銀行賬戶等重要許可權設定密碼的時候,我們常常遇到這樣的煩惱:如果為了好記用生日吧,容易被破解,不安全;如果設定不好記的密碼,又擔心自己也會忘記;如果寫在紙上,擔心紙張被別人發現或弄丟了...

這個程式的任務就是把一串拼音字母轉換為6位數字(密碼)。我們可以使用任何好記的拼音串(比如名字,王喜明,就寫:wangximing)作為輸入,程式輸出6位數字。

變換的過程如下:

第一步. 把字串6個一組摺疊起來,比如wangximing則變為:

wangxi

ming 

第二步. 把所有垂直在同乙個位置的字元的ascii碼值相加,得出6個數字,如上面的例子,則得出:

228 202 220 206 120 105

第三步. 再把每個數字「縮位」處理:就是把每個位的數字相加,得出的數字如果不是一位數字,就再縮位,直到變成一位數字為止。例如: 228 => 2+2+8=12 => 1+2=3

上面的數字縮位後變為:344836, 這就是程式最終的輸出結果!

要求程式從標準輸入接收資料,在標準輸出上輸出結果。

輸入格式為:第一行是乙個整數n(<100),表示下邊有多少輸入行,接下來是n行字串,就是等待變換的字串。

輸出格式為:n行變換後的6位密碼。

例如,輸入:

5zhangfeng

wangximing

jiujingfazi

woaibeijingtiananmen

haohaoxuexi

則輸出:

772243

344836

297332

716652

875843

注意:請仔細除錯!您的程式只有能執行出正確結果的時候才有機會得分!

在評卷時使用的輸入資料與試卷中給出的例項資料可能是不同的。

一開始我是想開闢乙個二維陣列來模擬的,後來想到了取餘,首先獲取字串的的長度len,然後讓i從0到len-1迴圈,定義乙個陣列num用來儲存六個ascii碼的和,每一次就讓num[i%6]+=str[i],這樣就可以讓在同一列上的字元的ascii碼相加得到和,然後再定義乙個函式用來壓縮數值,方法也很簡單,只要n>9,就把n中的每一位提取出來相加,最後把數值賦給n,也是用到了取餘的操作。

#include#include#includeusing namespace std;

int cut(int n)

n=sum;

}return n;

}int main()

; cin>>str;

len=strlen(str);

for(i=0;i

藍橋杯 密碼發生器

在對銀行賬戶等重要許可權設定密碼的時候,我們常常遇到這樣的煩惱 如果為了好記用生日吧,容易被破解,不安全 如果設定不好記的密碼,又擔心自己也會忘記 如果寫在紙上,擔心紙張被別人發現或弄丟了.這個程式的任務就是把一串拼音字母轉換為6位數字 密碼 我們可以使用任何好記的拼音串 比如名字,王喜明,就寫 w...

藍橋杯 密碼發生器

第一步 將字串轉換為一行只有6個字母的二維陣列 第二步 將每一列單獨加起來 第三部 遞迴處理資料直至只剩個位數 include includeusing namespace std int toonenum int n else return toonenum sum void change int...

密碼發生器 藍橋杯

這是2012年第三屆藍橋杯全國軟體大賽預賽 c 本科組 的第8題,問題是對字串的處理。在對銀行賬戶等重要許可權設定密碼的時候,我們常常遇到這樣的煩惱 如果為了好記用生日吧,容易被破解,不安全 如果設定不好記的密碼,又擔心自己也會忘記 如果寫在紙上,擔心紙張被別人發現或弄丟了.這個程式的任務就是把一串...