日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] Description: 密碼發(fā)生器 在對(duì)銀行賬戶等重要權(quán)限設(shè)置密碼的時(shí)候,我們常常遇到這樣的煩惱:如果為了好記用生日吧,容易被破解,不安全;如果設(shè)置不好記的密碼,又擔(dān)心自己也會(huì)忘記;如果寫(xiě)在紙上,

 

  1. Description:  密碼發(fā)生器  
  2.     在對(duì)銀行賬戶等重要權(quán)限設(shè)置密碼的時(shí)候,我們常常遇到這樣的煩惱:如果為了好記用生日吧,容易被破解,不安全;如果設(shè)置不好記的密碼,又擔(dān)心自己也會(huì)忘記;如果寫(xiě)在紙上,擔(dān)心紙張被別人發(fā)現(xiàn)或弄丟了...  
  3.     這個(gè)程序的任務(wù)就是把一串拼音字母轉(zhuǎn)換為6位數(shù)字(密碼)。我們可以使用任何好記的拼音串(比如名字,王喜明,就寫(xiě):wangximing)作為輸入,程序輸出6位數(shù)字。     變換的過(guò)程如下:  
  4.     第一步. 把字符串6個(gè)一組折疊起來(lái),比如wangximing則變?yōu)椋?nbsp; 
  5.     wangxi     ming   
  6.     第二步. 把所有垂直在同一個(gè)位置的字符的ascii碼值相加,得出6個(gè)數(shù)字,如上面的例子,則得出:  
  7.     228 202 220 206 120 105  
  8.     第三步. 再把每個(gè)數(shù)字“縮位”處理:就是把每個(gè)位的數(shù)字相加,得出的數(shù)字如果不是一位數(shù)字,就再縮位,直到變成一位數(shù)字為止。例如: 228 => 2+2+8=12 => 1+2=3     上面的數(shù)字縮位后變?yōu)椋?44836, 這就是程序最終的輸出結(jié)果!     要求程序從標(biāo)準(zhǔn)輸入接收數(shù)據(jù),在標(biāo)準(zhǔn)輸出上輸出結(jié)果。  
  9.     輸入格式為:第一行是一個(gè)整數(shù)n(<100),表示下邊有多少輸入行,接下來(lái)是n行字符串,就是等待變換的字符串。  
  10.     輸出格式為:n行變換后的6位密碼。      
  11. 例如,輸入: 5  
  12.             zhangfeng wangximing  
  13.             jiujingfazi  
  14.             woaibeijingtiananmen haohaoxuexi      
  15.             則輸出: 772243 344836 297332 716652 875843  
  16. Fuction List: 
  17. ************************************************************/  
  18. #include <stdio.h>  
  19. #include <string.h>  
  20.   
  21. int reduction(int m)  
  22. {  
  23.     int k = 0;  
  24.     if (m<10)  
  25.     {  
  26.         return m;  
  27.     }  
  28.     while(m)  
  29.     {  
  30.         k += m%10;  
  31.         m /= 10;  
  32.     }  
  33.       
  34.     return reduction(k);  
  35. }  
  36.   
  37. void f(char s[],char x[])  
  38. {  
  39.     int i,j,n,k;  
  40.     n = strlen(s);  
  41.     for (i=0; i<6; i++)  
  42.     {  
  43.         for (k=0,j=i; j<n; j+=6)  
  44.         {  
  45.             k += s[j];  
  46.         }  
  47.         x[i] = reduction(k) + '0';  
  48.     }  
  49.     x[6] = '\n';  
  50. }  
  51.   
  52. int main()  
  53. {  
  54.     char s[100] = {"wangximing"};  
  55.     char t[10000] = {""};  
  56.     int len = 0;  
  57.     int n;        // 有n行密碼  
  58.       
  59.     scanf ("%d",&n);  
  60.       
  61.     while (n)  
  62.     {  
  63.         n--;  
  64.         scanf ("%s",s);  
  65.         f(s,t+len);  
  66.         len += 7;  
  67.     }  
  68.     t[len-1] = '\0';  
  69.       
  70.     puts(t);  
  71.           
  72.     return 0;   
  73. }  
[cpp] view plain copy
 
 

 

  1. /********************************************************** 
  2. File Name:          
  3. Description:   4.取球游戲                
  4.                 今盒子里有n個(gè)小球,A、B兩人輪流從盒中取球, 
  5.                 每個(gè)人都可以看到另一個(gè)人取了多少個(gè),也可以 
  6.                 看到盒中還剩下多少個(gè),并且兩人都很聰明,不 
  7.                 會(huì)做出錯(cuò)誤的判斷。      
  8.                 我們約定:           
  9.                 每個(gè)人從盒子中取出的球的數(shù)目必須是:1,3,7或者8個(gè)。      
  10.                 輪到某一方取球時(shí)不能棄權(quán)!       
  11.                 A先取球,然后雙方交替取球,直到取完。       
  12.                 被迫拿到最后一個(gè)球的一方為負(fù)方(輸方)       
  13.                 請(qǐng)編程確定出在雙方都不判斷失誤的情況下,對(duì)于特定的初始球數(shù),A是否能贏?     
  14. Fuction List: 
  15. ************************************************************/  
  16. #include <stdio.h>  
  17.   
  18. int main()  
  19. {  
  20.     int a[16] = {0,1,0,1,0,1,0,1,1,1,1,1,1,1,1,1};  
  21.     int n[10001];  
  22.     int j[10001];  
  23.     int m;  
  24.     int i;  
  25.     int temp;  
  26.       
  27.     scanf("%d",&m);  
  28.     for(i = 0; i < m; i++)  
  29.     {  
  30.         scanf("%d",&n[i]);  
  31.         temp = n[i] % 15;  
  32.         j[i] = a[temp-1];  
  33.     }  
  34.       
  35.     for (i = 0; i < m; i++)  
  36.     {  
  37.         printf("%d\n",j[i]);  
  38.     }  
  39.       
  40.     return 0;  
  41. }  
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

鏈表作為一種基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),在程序設(shè)計(jì)中扮演著重要角色。掌握鏈表的高效操作技巧,特別是逆序、合并和循環(huán)檢測(cè),對(duì)于提升算法性能和解決復(fù)雜問(wèn)題至關(guān)重要。本文將詳細(xì)介紹這些操作的C語(yǔ)言實(shí)現(xiàn),并分析其時(shí)間復(fù)雜度。

關(guān)鍵字: 鏈表 C語(yǔ)言

在C/C++多文件編程中,靜態(tài)變量(static)與全局變量的作用域規(guī)則看似簡(jiǎn)單,實(shí)則暗藏諸多陷阱。開(kāi)發(fā)者若未能準(zhǔn)確理解其鏈接屬性與生命周期,極易引發(fā)難以調(diào)試的內(nèi)存錯(cuò)誤、競(jìng)態(tài)條件以及維護(hù)災(zāi)難。本文將深入剖析這兩類(lèi)變量的作...

關(guān)鍵字: 靜態(tài)變量 全局變量 C語(yǔ)言

在嵌入式系統(tǒng)和服務(wù)器開(kāi)發(fā)中,日志系統(tǒng)是故障排查和運(yùn)行監(jiān)控的核心組件。本文基于Linux環(huán)境實(shí)現(xiàn)一個(gè)輕量級(jí)C語(yǔ)言日志庫(kù),支持DEBUG/INFO/WARN/ERROR四級(jí)日志分級(jí),并實(shí)現(xiàn)按大小滾動(dòng)的文件輪轉(zhuǎn)機(jī)制。該設(shè)計(jì)在某...

關(guān)鍵字: C語(yǔ)言 嵌入式系統(tǒng)

在嵌入式系統(tǒng)和底層驅(qū)動(dòng)開(kāi)發(fā)中,C語(yǔ)言因其高效性和可控性成為主流選擇,但缺乏原生單元測(cè)試支持成為開(kāi)發(fā)痛點(diǎn)。本文提出一種基于宏定義和測(cè)試用例管理的輕量級(jí)單元測(cè)試框架方案,通過(guò)自定義斷言宏和測(cè)試注冊(cè)機(jī)制,實(shí)現(xiàn)無(wú)需外部依賴(lài)的嵌入...

關(guān)鍵字: C語(yǔ)言 嵌入式系統(tǒng) 驅(qū)動(dòng)開(kāi)發(fā)

在嵌入式系統(tǒng)開(kāi)發(fā)中,實(shí)時(shí)操作系統(tǒng)(RTOS)的任務(wù)調(diào)度算法直接影響系統(tǒng)的響應(yīng)速度和資源利用率。時(shí)間片輪轉(zhuǎn)(Round-Robin, RR)作為一種經(jīng)典的公平調(diào)度算法,通過(guò)為每個(gè)任務(wù)分配固定時(shí)間片實(shí)現(xiàn)多任務(wù)并發(fā)執(zhí)行。本文將...

關(guān)鍵字: 實(shí)時(shí)操作系統(tǒng) RTOS C語(yǔ)言

在Linux設(shè)備驅(qū)動(dòng)開(kāi)發(fā)中,等待隊(duì)列(Wait Queue)是實(shí)現(xiàn)進(jìn)程睡眠與喚醒的核心機(jī)制,它允許進(jìn)程在資源不可用時(shí)主動(dòng)放棄CPU,進(jìn)入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過(guò)C語(yǔ)言模型解析等待隊(duì)列的實(shí)現(xiàn)原理,結(jié)合...

關(guān)鍵字: 驅(qū)動(dòng)開(kāi)發(fā) C語(yǔ)言 Linux

在嵌入式系統(tǒng)開(kāi)發(fā)中,C語(yǔ)言與匯編的混合編程是優(yōu)化性能、訪問(wèn)特殊指令或硬件寄存器的關(guān)鍵技術(shù)。然而,內(nèi)聯(lián)匯編的語(yǔ)法差異和寄存器使用規(guī)則常導(dǎo)致難以調(diào)試的問(wèn)題。本文以ARM Cortex-M和x86架構(gòu)為例,系統(tǒng)梳理內(nèi)聯(lián)匯編的核...

關(guān)鍵字: C語(yǔ)言 匯編混合編程

在計(jì)算機(jī)安全領(lǐng)域,緩沖區(qū)溢出攻擊長(zhǎng)期占據(jù)漏洞利用榜首。這種攻擊通過(guò)向程序緩沖區(qū)寫(xiě)入超出其容量的數(shù)據(jù),覆蓋相鄰內(nèi)存區(qū)域(如返回地址),進(jìn)而實(shí)現(xiàn)任意代碼執(zhí)行。本文將深入探討棧保護(hù)機(jī)制與安全函數(shù)(如snprintf)的集成防御...

關(guān)鍵字: 棧保護(hù) 安全函數(shù) C語(yǔ)言

在嵌入式系統(tǒng)和大規(guī)模數(shù)值計(jì)算等性能敏感場(chǎng)景中,程序優(yōu)化是提升效率的關(guān)鍵環(huán)節(jié)。gprof作為GNU工具鏈中的性能分析工具,能夠精準(zhǔn)定位CPU時(shí)間消耗熱點(diǎn)。本文通過(guò)實(shí)際案例演示gprof的三個(gè)核心使用步驟,幫助開(kāi)發(fā)者快速識(shí)別...

關(guān)鍵字: C語(yǔ)言 gprof 熱點(diǎn)函數(shù)

哈希表作為高效數(shù)據(jù)檢索的核心結(jié)構(gòu),其性能高度依賴(lài)沖突解決策略。本文通過(guò)C語(yǔ)言實(shí)現(xiàn)對(duì)比鏈地址法與開(kāi)放尋址法,揭示兩種方法在內(nèi)存占用、查詢效率及實(shí)現(xiàn)復(fù)雜度上的差異,為工程實(shí)踐提供量化參考。

關(guān)鍵字: 哈希表 鏈地址法 開(kāi)放尋址法 C語(yǔ)言
關(guān)閉