国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

C編程:“最大子數組的和” 的動態(tài)規(guī)劃的解法

嵌入式技術 ? 來源:嵌入式技術 ? 作者:嵌入式技術 ? 2022-08-21 09:33 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

C編程筆試 --“最大子數組的和” 的動態(tài)規(guī)劃的解法

?1.最大子數組之和

例1:數組int a1[5] = { -1, 5, 6, -7, 3 };其最大子數組之和為:5+6=11
例2:數組int a2[5] = { -5, -4, -8, -1, -10 };其最大子數組之和為:-1
例3:數組 int a3[5] = { -1, 5, 6, -7, 10 };其最大子數組之和為:5+6-7+10=14

??功能實現:

# include 
# include 
int MaxSum(int* arr, int size)
{
    int current = arr[0]; //當前數組最大和
    int max = current;

    for (int i = 0; i < size; i++)
    {
        if (current < 0)
            current = 0;
        current += arr[i];
        if (current > max)
            max = current;
    }
    return max;
}

int main(void)
{
    char x[40], y[40];

    int a1[5] = { -1, 5, 6, -7, 3 };
    int a2[5] = { -5, -4, -8, -1, -10 };
    int a3[5] = { -1, 5, 6, -7, 10 };

    int max1, max2, max3;
    max1 = MaxSum(a1, 5);
    max2 = MaxSum(a2, 5); //這個應該返回 -1, 
    max3 = MaxSum(a3, 5);
	printf("max1=%d,max2=%d,max3=%d\n",max1,max2,max3);
}

?2.獲取最大子數組的開始和結束的下標

??如果我需要返回值返回這個最大子數組的開始和結束的下標,你要怎么修改這個程序?

例1:數組int a1[5] = { -1, 5, 6, -7, 3 };其最大子數組之和為:5+6=11;最大子數組開始和結束下標為:1 2。
例2:數組int a2[5] = { -5, -4, -8, -1, -10 };其最大子數組之和為:-1;最大子數組開始和結束下標為:3 3。
例3:數組 int a3[5] = { -1, 5, 6, -7, 10 };其最大子數組之和為:5+6-7+10=14 ; 最大子數組開始和結束下標為:1 4。
例4:數組 int a3[] = {-2, -1, -3, 4, -1, 2, 1, -5, 4};其最大子數組之和為:4+(-1)+2+1=6 ; 最大子數組開始和結束下標為:3 6。
??功能實現:

#include 
#include 
void solution(int m, int *arr){
    int current=arr[0];
    int max=current;
    int start=0,end=0;
    int i=0;
    /*計算最大子數組之和*/
    for(i=1;imax)
        {
            max = current;
            end=i;//最大子數組結束下標
        }
    }
	int temp=max;
	/*計算最大子數組結束下標*/
    for(i=end;i>=0;i--)
    {
	  temp-=arr[i];
      if(temp<=0 || temp>max)break;
    }
	if(i<0)i=0;
    start=i;
    printf("%d,%d %d\n",max,start,end);
}
int main() {
    int n;
	printf("輸入個數:");
    scanf("%d", &n);
    int *arr;
    arr = (int*)malloc(n * sizeof(int));
	printf("輸入%d個整數:",n);
    for (int i = 0; i < n; i++)
    {
        scanf("%d", &arr[i]);
    }
    solution(n, arr);
    return 0;
}
;i++)>

??運行結果:

pYYBAGMBfYaAP_I9AAMUkvwWkUo576.png#pic_center

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • C語言
    +關注

    關注

    183

    文章

    7644

    瀏覽量

    145576
  • 數組
    +關注

    關注

    1

    文章

    420

    瀏覽量

    27351
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    EN18031 認證全解析:三大子標準搞定歐盟網絡安全合規(guī)

    2026年歐盟網絡安全監(jiān)管持續(xù)收緊,EN18031作為RED指令強制網絡安全標準,已成為無線設備出海歐盟的核心門檻。該認證由三大子標準構成,分別對應不同安全場景,精準匹配即可高效完成合規(guī)。本文全面
    的頭像 發(fā)表于 02-06 15:41 ?1884次閱讀
    EN18031 認證全解析:三<b class='flag-5'>大子</b>標準搞定歐盟網絡安全合規(guī)

    RT-Thread Vector軟件包:嵌入式開發(fā)的動態(tài)數組容器 | 技術集結

    RT-Thread Vector軟件包:嵌入式開發(fā)的動態(tài)數組容器 | 技術集結
    的頭像 發(fā)表于 01-25 09:33 ?5375次閱讀
    RT-Thread Vector軟件包:嵌入式開發(fā)的<b class='flag-5'>動態(tài)</b><b class='flag-5'>數組</b>容器 | 技術集結

    keil中c語言的動態(tài)分配內存

    的大小(當然在C99中存在變長數組),但有時候我們也不能明確的指出要用多少空間,我們希望這塊空間可大可小,既不過大,造成空間浪費,也不能過小,不夠使用。這時就要用到我今天講到的動態(tài)內存分配了,通過
    發(fā)表于 01-21 06:04

    C語言嵌入式系統(tǒng)編程注意事項-內存操作

    啟動后第一條要執(zhí)行的指令的位置。 記住:函數無它,唯指令集合耳;你可以調用一個沒有函數體的函數,本質上只是換一個地址開始執(zhí)行指令! 數組vs動態(tài)申請 在嵌入式系統(tǒng)中動態(tài)內存申請存在比一般系統(tǒng)
    發(fā)表于 01-04 07:31

    C語言的編程技巧

    一個成員是一個未知大小的數組,適用于動態(tài)分配內存并關聯一個可變長度的數組。? ?3、匿名結構體和聯合體?:C語言允許在結構體或聯合體中定義不帶標簽的內部結構體或聯合體,簡化代碼結構。
    發(fā)表于 11-27 06:46

    數組的初體驗

    袋中的物品是按一定順序放置的。 1.我們來看一下如何聲明一個數組: 數據類型 數組名稱[長度]; 數組只聲明也不行啊,看一下數組是如何初始化的。說到初始化,
    發(fā)表于 11-25 08:06

    關于晶振的靜態(tài)電容與動態(tài)電容

    靜態(tài)電容與動態(tài)電容 C0與C1 的區(qū)別是什么呢?
    的頭像 發(fā)表于 11-21 15:38 ?4371次閱讀
    關于晶振的靜態(tài)電容與<b class='flag-5'>動態(tài)</b>電容

    基于感知引導的多步驟精細操作任務與運動規(guī)劃

    傳統(tǒng)的任務與運動規(guī)劃(TAMP)系統(tǒng)在機器人操作應用中通常依賴靜態(tài)模型運行,因此在面對新環(huán)境時往往表現不佳。將感知與操作相融合,是應對這一挑戰(zhàn)的有效途徑,使機器人能夠在執(zhí)行過程中實時更新規(guī)劃,從而適應動態(tài)變化的場景。
    的頭像 發(fā)表于 11-14 10:18 ?1457次閱讀
    基于感知引導的多步驟精細操作任務與運動<b class='flag-5'>規(guī)劃</b>

    基于SIMP與折衷規(guī)劃法的航空附件齒輪箱結構輕量化設計與動態(tài)特性提升

    航空發(fā)動機附件齒輪箱作為動力傳遞系統(tǒng)的關鍵部件,其箱體結構設計直接影響發(fā)動機的功率密度、可靠性及振動特性。針對傳統(tǒng)經驗設計方法難以滿足高剛度、輕量化及高動態(tài)性能要求的挑戰(zhàn),本文提出了一種基于折衷規(guī)劃法的多目標拓撲優(yōu)化方法。
    的頭像 發(fā)表于 11-07 15:21 ?740次閱讀
    基于SIMP與折衷<b class='flag-5'>規(guī)劃</b>法的航空附件齒輪箱結構輕量化設計與<b class='flag-5'>動態(tài)</b>特性提升

    Cognizant籌辦最大規(guī)模氛圍編程活動

    -Cognizant正在籌辦全球最大規(guī)模的氛圍編程活動,以提升數千名員工的AI素養(yǎng) 為抓住人工智能經濟將創(chuàng)造的巨大機遇,Cognizant與Lovable、Windsurf、Cursor
    的頭像 發(fā)表于 08-03 18:44 ?668次閱讀
    Cognizant籌辦<b class='flag-5'>最大</b>規(guī)模氛圍<b class='flag-5'>編程</b>活動

    在STM32F103c8上做DLQR最優(yōu)控制算法的C編程資料

    這是我近期做的一個項目--基于STM32F103c8的DLQR控制算法的C編程,涉及DLQR最優(yōu)控制算法、嵌入式STM32F103編程、CMSIS-DSP庫使用。? ??附有完整的程序
    發(fā)表于 07-23 15:30 ?0次下載

    AGV小車中的動態(tài)路徑規(guī)劃算法揭秘

    并非一成不變時,動態(tài)路徑規(guī)劃能力就顯得至關重要。本文將深入探討幾種主流的動態(tài)路徑規(guī)劃算法(如A、Dijkstra、RRT等),并解析它們如何在AGV行業(yè)中大顯身手。 為何需要
    的頭像 發(fā)表于 06-17 15:54 ?1692次閱讀
    AGV小車中的<b class='flag-5'>動態(tài)</b>路徑<b class='flag-5'>規(guī)劃</b>算法揭秘

    全球化市場調研新解法動態(tài)IP技術如何突破地域化數據壁壘

    當某國際智能家居品牌試圖通過TikTok分析東南亞消費者偏好時,發(fā)現不同國家用戶看到的推薦內容差異高達73%。這揭示了全球化市場調研的核心痛點——如何突破數字國界獲取真實本地數據。動態(tài)IP技術正在成為破局關鍵,但其應用遠非簡單的IP切換。
    的頭像 發(fā)表于 05-06 15:54 ?643次閱讀

    單片機c語言編程實例大全

    單片機c語言編程實例大全_18
    發(fā)表于 04-30 16:11 ?7次下載

    C++學到什么程度可以找工作?

    動態(tài)規(guī)劃、貪心算法等)。 3. **操作系統(tǒng)原理**:理解進程與線程、并發(fā)控制、同步機制(如互斥鎖、信號量等)、進程間通信等概念。 4. **網絡編程**:熟悉基于Socket的網絡編程
    發(fā)表于 03-13 10:19