1. 程式人生 > >[珠璣之櫝]二分思想與分治法、排序思想

[珠璣之櫝]二分思想與分治法、排序思想

#include <stdio.h>
#include <assert.h>

int BitCheck(int total,int n,int last) {
    FILE *input,*output0,*output1;
    char filename[10] = "";
    int mask,value,num0 = 0,num1 = 0;
    assert(n>=0);
    if(n==total)
        input = fopen("output.txt","r");
    else {
        sprintf(filename,
"%d_%d.txt",n,last); input = fopen(filename,"r"); } if(n==0) { sprintf(filename,"final_0"); output0 = fopen(filename,"w"); sprintf(filename,"final_1"); output1 = fopen(filename,"w"); } else { sprintf(filename,"%d_0.txt",n-1); output0
= fopen(filename,"w"); sprintf(filename,"%d_1.txt",n-1); output1 = fopen(filename,"w"); } assert(input!=NULL && output0!=NULL&&output1!=NULL); mask = 1<<n; while(!feof(input)) { fscanf(input,"%d\n",&value); if(value&mask) { fprintf(output1,
"%d\n",value); num1++; } else { fprintf(output0,"%d\n",value); num0++; } } fflush(output0); fflush(output1); fclose(output0); fclose(output1); fclose(input); return num1<num0; } int Search(int n){ int total = n,last = 0,missing =0; while(n>=0) { last = BitCheck(total,n,last); missing |= (last<<n); n--; } printf("missing number:%d\n",missing); return 0; } int main() { Search(14); return 0; }

相關推薦

[珠璣]二分思想治法排序思想

#include <stdio.h> #include <assert.h> int BitCheck(int total,int n,int last) { FILE *input,*output0,*output1; char filename[10

珠璣”系列簡介索引

系列博文主要目的:   收集《程式設計珠璣》和《程式設計珠璣(續)》(以下簡稱《續》)上的演算法和思想,幷包括了一些自己的思考和對相關問題的引申,以備複習和查用。 內容提要:   主要是演算法收集,結合了《程式設計實踐》 (Practise of Programming)、《程式設計精粹:編寫高質量C語

[珠璣]隨機數函式取樣概率

  本節主要受到《程式設計珠璣》第12章隨機取樣問題的啟發,但不僅僅限於隨機取樣問題,進一步地,研究討論了一些在筆試面試中常見的和隨機函式以及概率相關的問題。   閱讀本文所需的知識:     1.對C語言中或其他語言中等價的rand()、srand()有所瞭解。本文不討論種子的設定和偽隨機數的問題;

[珠璣]估算的應用Little定律

  估算的資料主要依賴於所能獲得的資料和常識,有時還包括實踐而不僅僅是理論。它常常作為一個大問題中的子問題,恰當地估算可以省去精確計算的時間和開銷。在計算機領域,所謂常識的內容很寬泛,比如硬碟的傳輸速度、CPU每秒能執行多少指令、各種資料結構的大小甚至每分鐘錄入的單詞數。有些資料是能夠從各種資料中查得的,但僅

治法的基本思想例子解析

    分治法的設計思想:將一個難以直接解決的大問題,分割成一些規模較小的相同問題,以便各個擊破,分而治之。     凡治眾如治寡,分數是也。——孫子兵法 1.基本思想 (1) 將求解的較大規模

遞歸治法

分治法 nbsp ima vid 技術 方程 bubuko divide .com 分治法思想 把問題分解為k個規模較小的子問題,這些子問題(互相獨立且)結構與原來問題的結構相同,再遞歸地求解這些子問題。 問題分解成子問題;(divide) 當達到某個閾值n0時,

最近點對問題蠻力法無內部排序治法有內部排序治法

#include <iostream> #include <vector> #include <algorithm> #include <string> #include <stdlib.h> #include <math.h>

Mybatis攔截器資料許可權過濾頁整合

解決方案之改SQL 原sql SELECT a.id AS "id", a.NAME AS "name", a.sex_cd AS "sexCd", a.org_id AS "orgId", a.STATUS AS "status", a.create_org_id AS "createOrgId"

【演算法課】遞迴治法

概述 演算法 若干指令組成的有窮序列。 輸入:零或多個外部輸入 輸出:至少一個輸出 確定性:每條指令無歧義 有限性:每條指令執行次數有限,總執行時間有限 複雜性 分時間和空間複雜性。 計算時間複雜度的時候,通過計算其核心語句的執行次數,匯出其關於問題規模N的複

軟體設計師演算法治法--歸併排序

    最近準備要考中級軟體設計師。該門考試涉及到演算法相關的,剛好也順帶著整理下之前自己學習過的知識。     演算法的學習沒有什麼捷徑,就是理解演算法思想和邏輯。最重要的一點,一定要自己編寫程式碼,除錯通過,這樣才算是完成了演算法的學習。      2路歸併排序就是每次

2 Elasticsearch 篇倒排索引

文章目錄 書的目錄與索引 正排與倒排索引簡介 倒排索引詳解 分詞介紹 analyze_api 自帶分詞器 Standard Analyzer Simple Analyzer W

演算法設計分析--求最大子段和問題(蠻力法治法動態規劃法) C++實現

演算法設計與分析--求最大子段和問題 問題描述: 給定由n個整陣列成的序列(a1,a2, …,an),求該序列形如 的子段和的最大值,當所有整數均為負整數時,其最大子段和為0。 利用蠻力法求解: int maxSum(int a[],int n) { int ma

[珠璣]字串和序列:左移雜湊最長重複子序列的字尾陣列解法最大連續子序列

  字串和陣列在儲存上是類似的,把它們歸為同一主題之下。本文主要介紹三大類問題和它們衍生的問題,以及相應演算法。   本文主要介紹和討論的問題和介紹的演算法(點選跳轉): 字串迴圈移位(左旋轉)問題 問題敘述:   將一個n元一維向量向左旋轉i個位置。例如,當n=8且i=3時,"abcde

[珠璣]位向量/點陣圖的定義和應用

  位向量/點陣圖是一個很有用的資料結構,在充分利用小空間儲存大量資料方面非常具有優勢,Linux核心中很多地方都是用了點陣圖。同時,它不但基礎,而且用到了很多程式語言的知識,以及對細節的把握,常常作為面試題出現。這裡將要介紹它的實現、操作、應用。   與點陣圖(bitmap)比,我更傾向於用位向量(bit

[珠璣]淺談程式碼正確性:迴圈不變式斷言debug

  這個主題和程式碼的實際寫作有關,而且內容和用法相互交織,以下只是對於其內容的一個劃分。《程式設計珠璣》上只用了兩個章節20頁左右的篇幅介紹,如果希望能獲得更多的例項和技巧,我比較推崇《程式設計實踐》 (Practise of Programming)、《程式設計精粹:編寫高質量C語言程式碼》(Writin

LeetCode Pow(x, n)(治法

【問題描述】 Implement pow(x, n). 1.【基礎知識】 1)分治的意識,一道O(N)的演算法題,琢磨出O(lgN)的思想出來就是要求; 2.【屌絲程式碼】 卡殼的地方: 1.Time Limit Exceeded。 #include <vecto

js演算法:治法-歸併排序合併有序陣列

     合併有序陣列是合併排序重要的一步,下面js演示了每一步的操作過程  附程式碼: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEA

演算法05:二分搜尋演算法——治法Part1

摘自網路: 分治法的設計思想是,將一個難以直接解決的大問題,分割成一些規模較小的相同問題,以便各個擊破,分而治之。 分治法所能解決的問題一般具有以下幾個特徵: 1.該問題的規模縮小因為問題的計算複雜性一般是隨著問題規模的增加 2.該問題可以分解為若干個規模較小的相同問題,即

大數據入門第二十二天——spark(三)自定義排序查找

get buffer arr clas ron arm scala mut all 一、自定義分區   1.概述     默認的是Hash的分區策略,這點和Hadoop是類似的,具體的分區介紹,參見:https://blog.csdn.net/high2011/arti

演算法導論 第二章:演算法入門 筆記 (插入排序迴圈不變式演算法分析最好和最壞時間複雜度選擇排序治法合併排序

插入排序: 排序問題的定義如下: 輸入:N個數{a1, a2,..., an }。 輸出:輸入序列的一個排列{a'1 ,a'1 ,...,a'n },使得a'n <=a' n<=...<