找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1586|回復(fù): 2
打印 上一主題 下一主題
收起左側(cè)

C語言選擇排序中交換數(shù)據(jù)的不同方式出現(xiàn)的不同結(jié)果 求分析

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:272485 發(fā)表于 2020-4-5 13:50 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. //選擇排序,升序
  2. void main()
  3. {
  4.     int i,min,j,t;
  5.     int a[5]={5,3,4,21,2};
  6.     for(i=0;i<4;i++)
  7.     {
  8.         min=i;//默認(rèn)此時的a[i]最小
  9.         for(j=i+1;j<5;j++)
  10.         {
  11.             if(a[min]>a[j])
  12.             {
  13.                 min=j;
  14.             }
  15.         }
  16.         if(min!=i)//找到了可以交換的數(shù)
  17.         {
  18.             min=a[i];//無t是5,21,2,3,4;有t是-85899346021234;用t來交換是234521
  19.             a[i]=a[min];
  20.             a[min]=min;
  21.         }
  22.     }
  23.     for(i=0;i<5;i++)
  24.     {
  25.         printf("%d,",a[i]);
  26.     }
  27. }
復(fù)制代碼

0.png (22.62 KB, 下載次數(shù): 117)

0.png
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:722908 發(fā)表于 2020-4-5 16:28 | 只看該作者
想要交換的話要有一個中間量啊,不然a[min]=min的時候min已經(jīng)是a[i]的指了,-858993460怎么出來的我也不清楚233
回復(fù)

使用道具 舉報

板凳
ID:272485 發(fā)表于 2020-4-5 17:15 | 只看該作者
這要看編譯器是如何在棧中組織臨時變量的,大部分編譯器會按照你定義的變量順序從棧底到棧頂安排存儲空間,所以按照你的定義順序,你的變量在棧中順序為:a[0],a[1],a[2],a[3],a[4],t,j,min,i,在t未刪除的情況下,初始值是0xCCCCCCCC,即十進(jìn)制有符號數(shù)-858993460,你第一次搜索時,i=0,a[0]=5,min=a[i]=5,接下來a[i]=a[min]執(zhí)行的是a[0]=a[5],a[5]不在數(shù)組中,正是t所在的位置,所以就出現(xiàn)1結(jié)果,刪除t后,溢出到j(luò)的位置,j此時的值是5,所以就出現(xiàn)2的結(jié)果,3是正確代碼得到的正確結(jié)果。
vs2017使用的編譯器不是按照你定義的順序組織變量,一般會先組織構(gòu)造類型,再組織常規(guī)類型。  
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表