主頁 > 後端開發 > C語言程式設計100例之(9):生理周期

C語言程式設計100例之(9):生理周期

2020-09-17 06:35:06 後端開發

例9    生理周期

問題描述

人生來就有三個生理周期,分別為體力、感情和智力周期,它們的周期長度為 23 天、28 天和33 天,每一個周期中有一天是高峰,在高峰這天,人會在相應的方面表現出色,例如,智力周期的高峰,人會思維敏捷,精力容易高度集中,因為三個周期的周長不同,所以通常三個周期的高峰不會落在同一天,對于每個人,我們想知道何時三個高峰落在同一天,

對于每個周期,我們會給出從當前年份的第一天開始,到出現高峰的天數(不一定是第一次高峰出現的時間),你的任務是給定一個從當年第一天開始數的天數,輸出從給定時間開始(不包括給定時間)下一次三個高峰落在同一天的時間(距給定時間的天數),例如:給定時間為10,下次出現三個高峰同天的時間是12,則輸出2(注意這里不是3),

輸入資料

輸入四個整數:p, e, i 和d, p, e, i 分別表示體力、情感和智力高峰出現的時間(時間從當年的第一天開始計算),d 是給定的時間,可能小于p, e, 或 i, 所有給定時間是非負的并且小于365, 所求的時間小于等于21252,

輸出要求

從給定時間起,下一次三個高峰同天的時間(距離給定時間的天數),

輸入樣例

0 0 0 0

0 0 0 100

5 20 34 325

4 5 6 7

283 102 23 320

-1 -1 -1 -1

輸出樣例

Case 1: the next triple peak occurs in 21252 days.

Case 2: the next triple peak occurs in 21152 days.

Case 3: the next triple peak occurs in 19575 days.

Case 4: the next triple peak occurs in 16994 days.

Case 5: the next triple peak occurs in 8910 days.

        (1)編程思路1,

假設從當年的第一天開始數,第k 天時三個高峰同時出現,符合問題要求的k必須大于d、小于等于21252(23×28×33),并滿足下列三個條件:

1)(k-p) % 23 == 0

2)(k-e) % 28 == 0

3)(k-i) % 33 == 0

對區間[d+1,21252]中的每個k都進行三個條件的判斷,若同時滿足三個條件,則k就是所求,

        (2)源程式1,

#include <stdio.h>

int main()

{

    int p,e,i,d,caseNo = 0,k;

    while(scanf("%d%d%d%d",&p,&e,&i,&d) &&p!=-1)

    {

        ++caseNo;

        for(k = d+1;(k-p)%23!=0 || (k-e)%28!=0|| (k-i)%33!=0; k++);

        printf("Case %d: the next triple peak occurs in %d days.\n",caseNo,k-d);

    }

    return 0;

}

        (3)編程思路2,

        思路1中對區間[d+1,21252]中的每個k都進行三個條件的判斷,開銷很大,可以進行優化,

        具體優化辦法是:先從區間[d+1,21252]中找到第一個滿足條件1)的體力高峰出現的時間k1,然后從k1、k1+23、k1+2*23、k1+3*23…這些時間中尋找第一個滿足條件2)的情感高峰出現的時間k2,當然它也一定是體力高峰出現的時間;最后在k2、k2+23*28、k1+2*23*28、k1+3*23*28…這些時間中尋找第一個滿足條件3)的時間k3,則k3-d就是所求的答案,

        (4)源程式2,

#include <stdio.h>

int main()

{

    int p,e,i,d,caseNo = 0,k;

    while(scanf("%d%d%d%d",&p,&e,&i,&d) &&p!=-1)

    {

        ++caseNo;

        for(k = d+1;(k-p)%23;k++);     // 列舉體力高峰

        while ((k-e)%28!=0)  k+=23;     // 列舉情感高峰

        while ((k-i)%33!=0)  k+=23*28;  // 找到三高峰

        printf("Case %d: the next triple peak occurs in %d days.\n",caseNo,k-d);

    }

    return 0;

}

習題9

9-1  硬幣方案

問題描述

有50枚硬幣,可能包括4種型別:1元、5角、1角和5分,

已知50枚硬幣的總價值為20元,求各種硬幣的數量,

例如:2、34、6、8就是一種方案,而2、33、15、0是另一個可能的方案,顯然方案不唯一,

撰寫程式求出類似這樣的不同的方案一共有多少種?

輸入資料

輸出要求

所有可能的方案,輸出格式見輸出樣例,

輸入樣例

無輸入

輸出樣例

1: 0 , 38 , 8 , 4

2: 1 , 36 , 7 , 6

3: 2 , 33 , 15 , 0

……

        (1)編程思路,

        直接對四種型別的硬幣的個數進行窮舉,其中,1元最多20枚、5角最多40枚、1角最多50枚、5分最多50枚,

        另外,如果以元為單位,則5角、1角、5分會化成浮點型資料,容易計算出錯,可以將1元、5角、1角、5分變成100分、50分、10分和5分,從而全部采用整型資料處理,

        (2)源程式,

#include <stdio.h>

int main()

{

    int a,b,c,d,cnt=0;

    for(a=0;a<=20;a++)

     for(b=0;b<=40;b++)

      for(c=0;c<=50;c++)

       for(d=0;d<=50;d++)

       {

                     if(a*100+b*50+c*10+d*5==2000 && a+b+c+d==50)

                     {

                            printf("%d: %d , %d , %d , %d\n",++cnt,a,b,c,d);

                     }

        }

    return 0;

        (3)窮舉優化,

        上面的程式采用窮舉法求解,比較簡單,但在窮舉結構的設定、窮舉引數的選取等方面存在著改進與優化的空間,

        一般來說,在采用窮舉法進行問題求解時,可從兩個方面來優化考慮,

        1)建立簡潔的數學模型,

        數學模型中變數的數量要盡量少,它們之間相互獨立,這樣問題解的搜索空間的維度就小,反應到程式代碼中,回圈嵌套的層次就少,例如,上面的程式中,采用變數a、b、c、d分別表示1元、5角、1角和5分硬幣的枚數,對這4個變數窮舉,回圈層次為4層,實際上這4個變數彼此間有兩個條件在約束,或者枚數等于50,或者總價值為20元,因此,可以只窮舉3個變數,另外一個變數通過約束條件求出,從而將回圈層次減少為3層,

        2)減小搜索的空間,

        利用已有的知識,縮小數學模型中各個變數的取值范圍,避免不必要的計算,反應到程式代碼中,回圈體被執行的次數就減少,例如,在窮舉時,先考慮1元的枚數a,最多為20枚(即0<=a<=20),再考慮5角的枚數b,若采用總價值不超過20元約束,則其枚數最多為(2000-a*100)/50枚(即0<=b<=(2000-a*100)/50),之后考慮1角的枚數c,其枚數最多為 (2000-a*100-b*50)/10(即0<=c<=(2000-a*100-b*50)/10),這樣窮舉的回圈次數會大大減少,

        采用上述思路優化后的源程式如下,

#include <stdio.h>

int main()

{

    int a,b,c,d,cnt=0;

    for(a=0;a<=20;a++)

     for(b=0;b<=(2000-a*100)/50;b++)

      for(c=0;c<=(2000-a*100-b*50)/10;c++)

        {

                     d=(2000-a*100-b*50-c*10)/5;    // 剩下的用5分硬幣填充

                     if(a+b+c+d==50)

                     {

                            printf("%d: %d , %d , %d , %d\n",++cnt,a,b,c,d);

                     }

        }

    return 0;

}

        也可以采用總枚數不超過50枚約束,先考慮1元的枚數a,最多為20枚(即0<=a<=20),再考慮5角的枚數b,則其枚數最多為(50-a)枚(即0<=b<=(50-a),之后考慮1角的枚數c,其枚數最多為 (50-a-b)枚(即0<=c<=50-a-b),采用這種思路優化后的源程式如下,

#include <stdio.h>

int main()

{

    int a,b,c,d,cnt=0;

    for(a=0;a<=20;a++)

     for(b=0;b<=50-a;b++)

      for(c=0;c<=50-a-b;c++)

            {

                     d=50-a-b-c;    // 剩下的用5分硬幣填充

                     if(100*a+50*b+10*c+5*d==2000)

                     {

                            printf("%d: %d , %d , %d , %d\n",++cnt,a,b,c,d);

                     }

            }

    return 0;

}

9-2  和積三角形

問題描述

把和為正整數s的8個互不相等的正整數填入8數字三角形(如圖1所示)中,若三角形三邊上的數字之和相等且三邊上的數字之積也相等,該三角形稱為和積三角形,

 

圖1  數字三角形

例如,和為45的和積三角形如圖2所示,

圖2  s=45的和積三角形

撰寫一個程式,輸出和為s的和積三角形,

輸入資料

一個正整數S(36≤S≤300),

輸出要求

所有和為S的和積三角形,要求輸出的方案不重復,如圖2中,8和9交換,或4和3交換,或同時交換9與4、8和3、2和12,所得到的3種方案均視為與圖2給出的方案是同一種方案,

輸入樣例

45

輸出樣例

1:2 , 8 , 9 , 1 , 4 , 3 , 12 , 6 ,   s1=20, s2=144

說明

對照圖2的資料,注意體會樣例中8個數的輸出順序,另外是s1的值代表各邊上整數的和,s2的值代表各邊上整數的積,

        (1)編程思路,

        按輸出樣例的說明,設圖1所示的數字三角形的8個數分布如下圖3所示,

        因為三角形的兩個腰可以互相交換,為避免重復,不妨約定三角形中數字“下小上大、左小右大”,即 b1<b7、b2<b3且b6<b5,

 

圖3  三角形分布示意圖

        這樣,可以根據約定對b1、b7的值進行回圈探索,設定:

        b1的取值范圍為1 ~ (s-21)/2;    (因除b1、b7外,其他6個數之和至少為21)

        b7的取值范圍為b1+1 ~ (s-28);  (因除b7外,其他7個數之和至少為28)

        b4的取值范圍為1 ~  (s-28);    (因除b4外,其他7個數之和至少為28)

        同理,根據約定b2<b3,b6<b5,可設定:

b2 的取值范圍為1 ~ (s-21)/2;   (因除b2、b3外,其他6個數之和至少為21)

b3 的取值范圍為b2+1 ~  (s-28);

b6 的取值范圍為1 ~  (s-21)/2;  (因除b5、b6外,其他6個數之和至少為21)

b5 的取值范圍為b(6)+1 ~  (s-28);

b8 = s-(b1+b2+b3+b4+b5+b6+b7)

對所取的8個整數,需要進行以下4道檢測:

1)若b8<=0,則不符合要求;

2)若這8個數出現相同數,則不符合要求;

3)若三邊之和不等,則不符合要求;

4)若三邊之積不等,則不符合要求,

若某8個數通過以上4道檢測,即為一個解,列印輸出,并統計解的個數,

        由于需要對8個整數中是否出現相同數進行檢測,因此可以將8個數保存在一個一維陣列中,定義一維陣列 int  b[9];其中陣列元素b[1] ~ b[8]分別對應圖3中的b1 ~ b8,

        程式總體可以寫成一個七重回圈結構,如下:

    for(b[1]=1;b[1]<=(s-21)/2;b[1]++)

     for(b[7]=b[1]+1;b[7]<=s-28;b[7]++)

      for(b[4]=1;b[4]<=s-28;b[4]++)

       for(b[2]=1;b[2]<=(s-21)/2;b[2]++)

        for(b[3]=b[2]+1;b[3]<=s-28;b[3]++)

         for(b[6]=1;b[6]<=(s-21)/2;b[6]++)

          for(b[5]=b[6]+1;b[5]<=s-28;b[5]++)

                     {

                            根據窮舉的8個數,進行4道檢測,確定是否為一組解;

                    }

        4道檢測中,除檢查8個數中是否出現相同數復雜點外,其他均是簡單計算并判斷即可,

        為檢測8個數中是否出現相同的數,可以先設定一個標志 t=0;然后用回圈依次將每個數與其后的每個數進行比較,若出現相同,則置t=1并退出回圈,

        回圈執行結束后,若 t==1,則說明8個數中出現了相同的數;若 t保持初始設定值0,則說明8個數中不存在相同的數,演算法描述為:

      t=0;

     for(i=1;i<=7;i++)

             for(j=i+1;j<=8;j++)

                         if(b[i]==b[j])

                          { 

                                     t=1; i=7; break;

                           }

        (2)源程式1,

#include <stdio.h>

int main()

{

    int i,j,t,s,s1,s2,cnt,b[9];

    scanf("%d",&s);

    cnt=0;

    for(b[1]=1;b[1]<=(s-21)/2;b[1]++)

     for(b[7]=b[1]+1;b[7]<=s-28;b[7]++)

      for(b[4]=1;b[4]<=s-28;b[4]++)

       for(b[2]=1;b[2]<=(s-21)/2;b[2]++)

        for(b[3]=b[2]+1;b[3]<=s-28;b[3]++)

         for(b[6]=1;b[6]<=(s-21)/2;b[6]++)

          for(b[5]=b[6]+1;b[5]<=s-28;b[5]++)

            {

                              b[8]= s-(b[1]+b[2]+b[3]+b[4]+b[5]+b[6]+b[7]);

                              if(b[8]<=0)  continue;

                              t=0;

                              for(i=1;i<=7;i++)

                                 for(j=i+1;j<=8;j++)

                                        if(b[i]==b[j])

                                        {  t=1; i=7; break; }

                           if(t==1)  continue;

                           s1= b[1]+b[2]+b[3]+b[4];

                           if(b[4]+b[5]+b[6]+b[7]!=s1 || b[1]+b[8]+b[7]!=s1)

                                     continue;

                           s2=b[1]*b[2]*b[3]*b[4];

                          if(b[4]*b[5]*b[6]*b[7]!=s2 || b[1]*b[8]*b[7]!=s2)

                                     continue;

                         cnt++;

                         printf("%d : ",cnt);

                         for(i=1; i<=8; i++)

                                 printf("%d , ",b[i]);

                         printf("  s1=%d, s2=%d\n",s1,s2);

            }

    return 0;

             }

        (3)窮舉優化思路,

        上面的窮舉程式設計雖然可行,但是,這個程式的運行速度太慢,例如將程式中的s=45改成s=89,即計算和為89的8個整陣列成的和積三角形,程式運行后,可得到如下所示的結果,

1 : 6 , 14 , 18 , 1 , 9 , 8 , 21 , 12 ,   s1=39, s2=1512

2 : 8 , 12 , 15 , 1 , 16 , 9 , 10 , 18 ,   s1=36, s2=1440

3 : 8 , 4 , 27 , 2 , 12 , 3 , 24 , 9 ,   s1=41, s2=1728

4 : 15 , 9 , 16 , 1 , 12 , 10 , 18 , 8 ,   s1=41, s2=2160

        程式得到以上4個解需等待較長時間,為了提高求解效率,必須對程式進行優化,可以從回圈設定入手,具體思路為:

       1)增加s+b1+b7+b4是否為3的倍數檢測,

        因為三角形三個頂點的元素在計算三邊時各計算了兩次,即s+b1+b7+b4=3*s1,則在b1、b4、b7回圈中增加對s+b1+b7+b4是否能被3整除的檢測,

        若(s+b1+b7+b4)%3≠0,則直接continue,繼續新的b1、b4、b7探索,而無需探索后面的b2、b3、b5和b6;

        否則,記s1=(s+b1+b7+b4)/3,往下進行探索,

        2)精簡回圈,把七重回圈精簡為五重,

        保留根據約定對b1、b7和b4的值進行的回圈探索,設定同前,優化對b2、b3、b5和b6的回圈探索,可根據約定對b3、b5的值進行探索,設定:

b3的取值范圍為(s1-b1-b4)/2+1 ~  s1-b1-b4;   注: s1=(s+b1+b7+b4)/3

b5的取值范圍為(s1-b4-b7)/2+1 ~  s1-b4-b7;

同時根據各邊之和為s1,計算出b2、b6和b8,即

         b2=s1-b1-b4-b3

         b6=s1-b4-b5-b7

         b8=s1-b1-b7

       這樣,還同時精簡了關于b8是否為正的檢測,也精簡了三邊和是否相等的檢測,只需檢測b陣列是否存在相同正整數與三邊積是否相同即可,

        (4)改進后的源程式,

#include <stdio.h>

int main()

{

    int i,j,t,s,s1,s2,cnt,b[9];

    scanf("%d",&s);

    cnt=0;

    for(b[1]=1;b[1]<=(s-21)/2;b[1]++)

     for(b[7]=b[1]+1;b[7]<=s-28;b[7]++)

      for(b[4]=1;b[4]<=s-28;b[4]++)

        {

                  if((s+b[1]+b[4]+b[7])%3!=0)

                            continue;

                  s1=(s+b[1]+b[4]+b[7])/3;

                 for(b[3]=(s1-b[1]-b[4])/2+1;b[3]<s1-b[1]-b[4];b[3]++)

                     for(b[5]=(s1-b[4]-b[7])/2+1;b[5]<s1-b[4]-b[7];b[5]++)

                      {

                              b[2]=s1-b[1]-b[4]-b[3];

                               b[6]=s1-b[4]-b[7]-b[5];

                              b[8]=s1-b[1]-b[7];

                              t=0;

                              for (i=1; i<=7; i++)

                                 for(j=i+1;j<=8;j++)

                                        if(b[i]==b[j])

                                       { t=1;  i=7; break; }

                             if(t==1)  continue;

                             s2=b[1]*b[2]*b[3]*b[4];

                            if(b[4]*b[5]*b[6]*b[7]!=s2 || b[1]*b[8]*b[7]!=s2)

                                   continue;

                           cnt++;

                          printf("%d : ",cnt);

                         for(i=1; i<=8; i++)

                                 printf("%d , ",b[i]);

                         printf("  s1=%d, s2=%d\n",s1,s2);

                     }

           }

    return 0;

}

        運行以上改進窮舉的程式,當s=89時所得解與前相同,但時間大大縮短,

9-3  完美運算式

問題描述

把數字1、2、…、9這9個數字填入以下含加減乘除與乘方的綜合運算式中的9個□中,使得該式成立

         □^□+□□÷□□-□□×□=0  

要求數字1,2,…、9這9個數字在式中都出現一次且只出現一次,

輸入資料

輸出要求

輸出所有可能的填寫方式,輸出格式見輸出樣例,

輸入樣例

輸出樣例

1:3 ^ 5 + 87 / 29 - 41 * 6=0

 ……

        (1)編程思路1,

        設式中的6個整數從左至右分別為 a、b、x、y、z、c,其中x、y、z為2位整數,范圍為12~98;a、b、c為一位整數,范圍為1~9,

        設定a、b、c、x、y、z回圈,對窮舉的每一組a、b、c、x、y、z,進行以下檢測:

        1)若x不是y的倍數,即 x % y!=0,則回傳繼續下一次窮舉,

        2)若等式不成立,即a^b+x/y-z*c!=0,則回傳繼續下一次窮舉,

3)式中9個數字是否存在相同數字,將式中6個整數共9個數字進行分離,分別賦值給陣列元素f[1]~f[9],連同附加的f[0]=0(為保證9個數字均不為0),共10個數字在二重回圈中逐個比較,

若存在相同數字,t=1,不是解,繼續下一次窮舉,

若不存在相同數字,即式中9個數字為1~9不重復,保持標記t=0, 是一組解,輸出所得的完美運算式,并統計解的個數 n ,

      (2)源程式1,

#include <stdio.h>

int main()

{

    int a,b,c,x,y,z;

    int i,j,k,t,n,f[10];

    n=0;

    for(a=1;a<=9;a++)

     for(b=1;b<=9;b++)

      for(c=1;c<=9;c++)

       for(x=12;x<=98;x++)

        for(y=12;y<=98;y++)

         for(z=12;z<=98;z++)

         {

                   if (x%y!=0) continue;

                    k=1;

                    for (i=1;i<=b;i++)     // 計算k=a^b

                       k=a*k;

                   if(k+x/y-z*c!=0) continue;

                   f[0]=0;

                  f[1]=a;f[2]=b;f[3]=c;   //  9數字個賦給f陣列

                  f[4]=x/10; f[5]=x%10;

                  f[6]=y/10; f[7]=y%10;

                  f[8]=z/10; f[9]=z%10;

                   t=0;

                   for(i=0;i<=8;i++)

                    for(j=i+1;j<=9;j++)

                         if(f[i]==f[j])

                         { t=1; break; }      //  檢驗數字是否有重復

                    if(t==0)

                    {

                        n++;             //  輸出一個解,用n統計個數

                        printf("%d:%d ^ %d + %d / %d - %d * %d=0\n",n,a,b,x,y,z,c);

                    }

           }

    return 0;

}

         (3)編程思路2,

        對上面的程式進行優化,

        由于要求的綜合運算式為:a^b+x/y-z*c=0,那么,x=(z*c-a^b)*y,因此可設定a、b、c、y、z回圈,對窮舉的每一組a、b、c、y、z,計算x,這樣處理,可省略x回圈,同時省略x是否能被y整除,省略等式是否成立的檢測,

        計算x后,只要檢測x是否為二位數即可,若計算所得x不是二位整數,則回傳繼續下一次窮舉,

        另外,式中9個數字是否存在相同數字可采用這樣的方法:

        定義f陣列對6個整數分離出的9個數字的出現次數進行統計,即f[i]的值為式中數字i的個數,初值全賦值為0,統計后,若某一f[i](i=1~9)不為1,則一定不滿足數字1、2、…、9這九個數字都出現一次且只出現一次,標記t=1,不是解,回傳繼續下一次窮舉;若所有f[i]全為1,滿足數字1、2、…、9這九個數字都出現一次且只出現一次,保持標記t=0,是解,輸出所得的完美綜合運算式,

        (4)源程式2,

#include <stdio.h>

int main()

{

    int a,b,c,x,y,z;

    int i,k,t,n,f[10];

    n=0;

    for(a=1;a<=9;a++)

     for(b=1;b<=9;b++)

      for(c=1;c<=9;c++)

        for(y=12;y<=98;y++)

         for(z=12;z<=98;z++)

          {

                 k=1;

                for (i=1;i<=b;i++)

                        k=a*k;

                x=(z*c-k)*y;

                if(x<10 || x>98)  continue;

                for(i=1;i<=9;i++)

                        f[i]=0;

                f[a]++; f[b]++; f[c]++;   //  記錄9個數字各自出現的次數

                f[x/10]++;  f[x%10]++;   f[y/10]++;  f[y%10]++;

                 f[z/10]++;  f[z%10]++;

                 t=0;

               for(i=1;i<=9;i++)

                    if(f[i]!=1)

                    { t=1; break; }      //  檢驗數字是否有重復

              if(t==0)

                {

                         n++;

                        printf("%d:%d ^ %d + %d / %d - %d * %d=0\n",n,a,b,x,y,z,c);

                 }

           }

     return 0;

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/63319.html

標籤:C

上一篇:C語言程式設計100例之(8):尼科徹斯定理

下一篇:C語言程式設計100例之(10):最大公約數

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more