日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

分治应用--万里挑一 找假硬币

發布時間:2024/7/5 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 分治应用--万里挑一 找假硬币 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

    • 1. 問題描述
    • 2. 解題思路
    • 3. 代碼實現

1. 問題描述

n 個硬幣中有1枚是假幣,真假幣唯一的區別是假幣重量輕,如何快速找出假幣

2. 解題思路

  • 暴力做法,一個一個的稱重,O(n)復雜度
  • 分治思路
  • 將硬幣等分成兩份,若為奇數,多出一枚,放在天平兩邊
  • 輕的一邊包含假幣,若相等,則假幣是多出的那一枚
  • 對輕的一邊繼續上述操作,直到找出假幣
    復雜度O(log n)
  • 3. 代碼實現

    /*** @description: n 個硬幣中有1枚是假幣,假幣重量輕,如何快速找出假幣* @author: michael ming* @date: 2019/7/6 20:37* @modified by: */ #include <iostream> #include <ctime> #include <random> using namespace std; int findcoin(int *weight, int left, int right, int &weightimes) {if(left+1 == right)//只有2枚硬幣{weightimes++;//稱重比較一次if(weight[left] < weight[right])return left;//返回重量小的位置elsereturn right;}int i, mid, weightsumL, weightsumR;weightsumL = weightsumR = 0;mid = left + (right-left)/2;if((right-left+1)%2 == 0)//偶數枚銀幣{weightimes++;for(i = left; i <= mid; ++i)weightsumL += weight[i];//計算左邊重量(計算機沒有天平,只能一個個加)for(i = mid+1; i <= right; ++i)weightsumR += weight[i];//右邊重量if(weightsumL > weightsumR)//左邊重,假幣在右邊return findcoin(weight,mid+1,right,weightimes);else if(weightsumL < weightsumR)//假幣在左邊return findcoin(weight,left,mid,weightimes);else//假幣不在兩邊(偶數枚銀幣);//什么都不做,不必再找了}else//奇數枚硬幣{weightimes++;for(i = left; i <= mid-1; ++i)weightsumL += weight[i];//計算左邊重量for(i = mid+1; i <= right; ++i)weightsumR += weight[i];//右邊重量if(weightsumL > weightsumR)//左邊重,假幣在右邊return findcoin(weight,mid+1,right,weightimes);else if(weightsumL < weightsumR)//假幣在左邊return findcoin(weight,left,mid-1,weightimes);else//兩邊相等(奇數枚硬幣),剩余的那個是假幣return mid;} } int main() {srand(unsigned(time(0)));int num, i, weightimes = 0;cout << "請輸入硬幣總個數:";cin >> num;const int coinNum = num;int *weight = new int [coinNum];for(i = 0; i < coinNum; ++i){weight[i] = 10;}i = rand()%num;weight[i] = 9; //隨機生成假幣for(i = 0; i < coinNum; ++i)//打印硬幣信息{cout << i + 1 << " 硬幣重量: " << weight[i] << endl;}cout << "假硬幣是第" << findcoin(weight,0,coinNum-1,weightimes)+1 << "個。" << endl;cout << "共稱了" << weightimes << "次,找到假幣。";delete[]weight;return 0; }

    輸入 2500枚、5001枚,100萬枚,最多需要 log2n 向上取整次就能找到。



    總結

    以上是生活随笔為你收集整理的分治应用--万里挑一 找假硬币的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 一区视频网站 | av2014天堂网| 亚洲青涩网 | 国产xxxx做受性欧美88 | 欧美成人三级在线视频 | 国产裸体永久免费无遮挡 | 免费视频久久久 | 手机在线观看av片 | 伊人免费| 日本免费网站 | 日韩日b视频 | 久久视频网 | 精品视频导航 | 一级特黄色 | 青青草草| 亚洲www色| 伊人精品综合 | 一区二区欧美在线观看 | 麻豆69 | 亚洲一本二本 | 日韩欧美亚洲天堂 | 熊猫电影yy8y全部免费观看 | 一区二区三区久久 | 婷婷国产视频 | 午夜久久久久久久久久影院 | 日韩一区免费视频 | 人人爱人人插 | 91插插插插插插插 | 日本性xxxxx 免费毛片视频网站 | 无码aⅴ精品一区二区三区浪潮 | 天堂网在线观看 | 中文在线视频 | 日韩久久一区二区 | а√中文在线资源库 | 色欲av无码精品一区 | 四虎av影视 | 一本高清dvd在线播放 | 亚洲天堂手机在线观看 | 99九九久久 | 成人一区二区在线观看 | 欧美日韩免费一区二区 | 国产高清色 | 久久久香蕉视频 | 黄色片网站免费在线观看 | 免费黄色网址观看 | www.日本在线视频 | 成人无码av片在线观看 | 成年人视频在线看 | 成人免费高清在线播放 | 日本少妇做爰全过程毛片 | 国产一线二线在线观看 | 欧美大片一区二区 | 无码国产精品一区二区免费16 | 午夜影院日本 | youjizzxxx69| 色综合久久久 | 亚洲自拍成人 | 漂亮人妻被中出中文字幕 | 女人久久久久 | 国产淫语对白 | 亚洲av无码国产精品麻豆天美 | 少妇毛片一区二区三区 | 日本黄色大片在线观看 | 中文字幕第5页 | 国产在线国偷精品免费看 | 黄色网页大全 | 91视频播放器| 国产网站无遮挡 | 妺妺窝人体色www聚色窝仙踪 | 久久久一 | 高潮videossex高潮 | 波多野结衣免费看 | 欧美xxxxxx片免费播放软件 | 欧美日韩中文字幕视频 | 亚洲国产精品18久久久久久 | 玖玖网| 亚洲女同一区二区 | wwwxxx在线观看 | 亚洲国产成人va在线观看天堂 | 日韩男人的天堂 | 午夜天堂影院 | 日韩精品在线播放 | 国产欧美日韩精品在线 | 国产馆av | 精品少妇v888av | 欧美一区二区三区视频 | 国产视频最新 | 欧美视频一区二区三区四区在线观看 | 姐姐av| 奇米影视四色7777 | 色播日韩| 青草99| 亚洲天堂成人网 | 免费三级在线 | 婷婷俺也去 | 天天操你 | 波多野结衣中文字幕一区二区三区 | 91av在线免费 | 黑人干亚洲人 |