撲克牌翻牌問題(遞歸)

撲克牌翻牌問題

題目描述:

有52張牌,使它們全部正面朝上,從第2張開始,凡是2的倍數位置上的牌翻成正面朝下;接著從第3張牌開始,凡是3的倍數位置上的牌,正面朝上的翻成正面朝下,正面朝下的翻成正面朝上;接著第三輪從第4張牌開始,凡是4的倍數位置上的牌按上面相同規則翻轉,以此類推,直到第1張要翻的牌是第52張為止。統計最后有幾張牌正面朝上,以及它們的位置號。
輸出:
1,4,9,16,25,36,49,
代碼如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
bool card[100];
void turn(int x)
{
if(x>52)return;
for(int i=x;i<=52;i+=x)
{
card[i]=!card[i];
}
turn(x+1);
}
int main()
{
memset(card,1,sizeof(card));
turn(2);
for(int i=1;i<=52;i++)
{
if(card[i])
cout<<i<<endl;
}
return 0;
}

/*運用了遞歸算法,從2的倍數一直翻到52的倍數,不斷地重復著類似的事情,采用遞歸去做;
一個知識漏洞 bool a[30]={1},這是剛開始賦值時,只是a[0]=1;因為全局賦值只能全部賦值0,即a[30]={0}
接下來進行一下擴展:
完全平方數的約數的個數是奇數。普通合數和質數的約數個數為偶數。
因為一個數的約數一定是兩兩出現的,但是完全平方數其中一對約數是一樣的,所以其約數是奇數個;
分析:因為一開始時正面,最后也是正面,那么一定最后是正面的被翻了偶數次,最后是反面的一定被翻了奇數次;
所以 最后是正面的數 都是完全平均數。
以上 是我在網上學到的*/

轉載于:https://www.cnblogs.com/zzyh/p/6601764.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/253072.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/253072.shtml
英文地址,請注明出處:http://en.pswp.cn/news/253072.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

以太網自動協商原理

自協商基本原理 自動協商模式是端口根據另一端設備的連接速度和雙工模式&#xff0c;自動把它的速度調節到最高的公共水平&#xff0c;即線路兩端能具有的最快速度和雙工模式。 自協商功能允許一個網絡設備能夠將自己所支持的工作模式信息傳達給網絡上的對端&#xff0c;并接受…

Python學習-文件的調用-讀取

1.文件的打開 open(filename[,mode[,buffering]]) #這個一定要記得關文件。close.() filename,要以路徑的形式展示&#xff0c;比如在"c:\"中&#xff0c;則要這樣寫: rc:\filename 如果不用路徑展示&#xff0c;那就用filename.其會在執行文件所在的文件夾進行搜索…

javascript . 05 json的組成、for...in 遍歷對象、簡單數據類型與復雜數據類型的傳值與傳址、內置對象...

對象字面量 JSON var obj { aaa :999};   var json{"aaa":999&#xff0c;“bbb”&#xff1a;888}; ”kay“&#xff1a;value 對象字面2??定義方法和json很像&#xff0c;只有一點不同&#xff0c;json的key 必須加“”   &#xff1b; 對象&#xff0c;數…

nohup命令

nohup命令 起因 ssh到機器上&#xff0c;然后執行某個程序&#xff0c;再登錄發現程序早就不運行了。 原因 ssh過去之后&#xff0c;執行的大部分命令&#xff08;守護進程不會斷開&#xff09;&#xff0c;都是ssh進程的子進程&#xff0c;ssh斷開&#xff0c;命令自然會中斷 …

mac與phy如何實現網絡自適應

這兩天修改網卡驅動以實現10/100/1000M自適應&#xff0c;因此研究了下phy芯片和emac驅動如何兼容10/100/1000M網絡環境&#xff0c;記錄在此。 網絡中設備端數據鏈路層由mac芯片和phy芯片組成&#xff0c;phy芯片根據外部網絡環境完成自動協商以及配置&#xff0c;驅動中根據p…

asp.net(mvc) 框架

1、NFine mvcef 2、Grove orm架構 3、NHibernate orm 4、NBear 5、petshop 6、Membership 7、Brnshop 網上商城 8、cms快速開發&#xff1a;http://www.open-open.com/news/view/a90f1 9、c#開源框架&#xff1a;http://www.cnblogs.com/gaoyuchuanIT/articles/5612268.html 來…

LVM邏輯卷詳解及創建

我們先來看一下這張圖片&#xff1a;PV: 底層的一個硬盤設備&#xff0c;可以是一個分區&#xff0c;也可能是一個RAID。我們可以把這個塊設備創建成一個物理卷格式&#xff0c;即一個PV。VG: 將一個或多個PV提供的存儲空間在一個更低的單位上劃分成一個個獨立的存儲單元&#…

python文件操作總結

python中對文件、文件夾&#xff08;文件操作函數&#xff09;的操作需要涉及到os模塊和shutil模塊。 得到當前工作目錄&#xff0c;即當前Python腳本工作的目錄路徑: os.getcwd() 返回指定目錄下的所有文件和目錄名:os.listdir() 函數用來刪除一個文件:os.remove() 刪除多個目…

Fread 和fwrite的參數不同,返回值不同

函數fwrite 功能C語言函數&#xff0c;向文件寫入一個數據塊 。size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream);注意&#xff1a;這個函數以二進制形式對文件進行操作&#xff0c;不局限于文本文件返回值&#xff1a;返回實際寫入的數據塊數目&…

課程簡介及算法分析

先學課程 -概率論 運行時間&#xff08;running time&#xff09; - 輸入&#xff08;eg 已經排序&#xff09; - 輸入規模&#xff08;6和6*10^9&#xff09; 各種各樣的分析&#xff1a; - 最壞情況分析&#xff08;worst case&#xff09;usually T(n) max time when inp…

利用shell腳本添加環境變量

在shell腳本設置了環境變量&#xff0c;如export LIBRARY_PATH./lib/&#xff0c;執行了此腳本后, 在執行生成的可執行文件&#xff0c;提示錯誤 error while loading shared libraries: libww.so: cannot open shared object file: No such file or directory 但是如果把expor…

2017 ACM-ICPC西安網賽B-Coin

B-Coin Bob has a not even coin, every time he tosses the coin, the probability that the coins front face up is \frac{q}{p}(\frac{q}{p} \le \frac{1}{2})?p??q??(?p??q??≤?2??1??). The question is, when Bob tosses the coin kktimes, whats the pr…

Java第四次作業

Dog dognew Dog("哈士奇","黑白",2);System.out.println(dog);}}class Dog {private String name;private String color;private int age;public String getName(){return name;}public String getColor(){return color;}public int getAge(){return age;}…

ITU-RBT.656視頻標準接口

601是SDTV的數據結構 656是SDTV的interface 709是HDTV的數據結構 1120是HDTV的interface ITU-R BT.601是演播室數字電視編碼參數標準&#xff0c;而ITU-R BT.656 則是ITU-R BT.601附件A中的數字接口標準&#xff0c; 用于主要數字視頻設備(包括芯片)之間采用27Mhzs并口或243Mb…

C語言博客作業03--函數

1.本章學習總結 1.1思維導圖 1.2本章學習體會及代碼量學習體會 1.2.1學習體會 本周學習了函數&#xff0c;其實&#xff0c;函數于之前學習的三大控制結構是密不可分的&#xff0c;而函數又有其特殊的地方&#xff0c;例如&#xff1a;函數的聲明、函數的調用等等。我們之前編寫…

Shell記錄-Shell命令(其他)

top命令是Linux下常用的性能分析工具&#xff0c;能夠實時顯示系統中各個進程的資源占用狀況&#xff0c;類似于Windows的任務管理器。 &#xff0e;命令格式 top [參數]Shell2&#xff0e;命令功能 顯示當前系統正在執行的進程的相關信息&#xff0c;包括進程ID、內存占用率、…

Insta360:從軟到硬,一年做出360°全景相機,中間填了多少坑?

摘要劉靖康在大學就開始創業。在大二的時候他曾經去騰訊實習&#xff0c;然后又去了“超級課程表”這個團隊實習半年&#xff0c;2013 年 9 月回到南京創業&#xff0c;一開始的產品叫“名校直播”&#xff0c;是一款圍繞院校名師講座所做的視頻直播產品。 不久前&#xff0c;一…

No.10 awk、變量、運算符、if多分支

awk、變量、運算符、if多分支 awk語法 ~ awk -F: {print $3,$4} /etc/passwd //-F指定:分隔符 默認以空格作為分隔符 ~ awk -F: {print &0,NF} //$0打印全部,NF有幾段內容 ~ awk -F: {print $NF} /etc/passwd //$NF打印最后一段內容 ~ awk -F: {print NR} /etc/passwd…

什么是自然語言處理技術

自然語言處理&#xff08;NLP&#xff09;是計算機科學&#xff0c;人工智能&#xff0c;語言學關注計算機和人類&#xff08;自然&#xff09;語言之間的相互作用的領域。自然語言處理是計算機科學領域與人工智能領域中的一個重要方向。它研究能實現人與計算機之間用自然語言進…

SDOI2005 區間

題目描述 現給定n個閉區間[ai, bi]&#xff0c;1<i<n。這些區間的并可以表示為一些不相交的閉區間的并。你的任務就是在這些表示方式中找出包含最少區間的方案。你的輸出應該按照區間的升序排列。這里如果說兩個區間[a, b]和[c, d]是按照升序排列的&#xff0c;那么我們有…