密碼發生器——第三屆藍橋杯省賽C語言A組第8題

在對銀行賬戶等重要權限設置密碼的時候,我們常常遇到這樣的煩惱:如果爲了好記用生日吧,容易被破解,不安全;如果設置不好記的密碼,又擔心自己也會忘記;如果寫在紙上,擔心紙張被別人發現或弄丟了...
這個程序的任務就是把一串拼音字母轉換爲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位密碼。


例如,輸入:

5
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi

則輸出:
772243
344836
297332
716652

875843

分析:

該題主要是字符串的處理,採用取substr取子串,用(int)char獲得字符的ASCII碼

#include <iostream>
#include <string>
#include <cstring>
#include <sstream>
#include <vector>
using namespace std;

int a[7];//存放縱向字符ASCII值的加和
vector<string> v;//存放六個字符長度的字符串

void sum(string s)
{
    for(int i=0;i<6;i++)
    {
        if(i+1>s.length()) a[i]+=0;//字符串長度小於6,則加零
        else a[i]+=(int)s[i];//把所有垂直在同一個位置的字符的ascii碼值相加
    }
}

int main()
{
    int n;
    string s1,s2;
    while(cin>>n)
    {
        for(int i=0;i<n;i++)
        {
            v.clear();
            cin>>s1;
            for(int j=0;j<s1.length();j+=6)
            { //將密碼字符串按照每6個分成一段
                if(j+6<=s1.length()) s2=s1.substr(j,6);
                else s2=s1.substr(j,s1.length()-j);
                v.push_back(s2);
            }
            memset(a,0,sizeof(a));
            for(int j=0;j<v.size();j++) sum(v[j]);
            for(int j=0;j<6;j++)
            {
                while(a[j]>9) a[j]=a[j]/100+a[j]%100/10+a[j]%10;//縮位
                cout<<a[j];
            }
            cout<<endl;
        }
    }
}



發佈了55 篇原創文章 · 獲贊 2 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章