當前位置:首頁 » 編程語言 » 求眾數c語言

求眾數c語言

發布時間: 2022-07-22 02:43:16

『壹』 c語言編程:眾數

數組排序可以不用指針。你把數組定義成全局變數,比如說a[10001];然後調用我給你的快排程序就行了,這個程序可以背下來,很有用的。
void qs(int L,int R)
{
int i=L,j=R,mid=a[(L+R)/2],t;
while(i<j)
{
while(a[i]<mid) ++i;
while(a[j]>mid) --j;
if(i<=j)
{
t=a[i]; a[i]=a[j]; a[j]=t;
++i; --j;
}
}

if(i<R) qs(i,R);
if(L<j) qs(L,j);
}
排好序之後找中位數就好辦了。
至於眾數,我覺得最好的方法是用bfs。但這個對你來說難度有點大,我就給你寫一個hash表吧。還用上面的那個數組,且假定數組a中的最大值不超過10000,若超過,你把下面這個hash數組的范圍擴大就行了。
另外,設a中有n個元素,a從1開始計數(若從0開始,你改一下就好了)
int hash[10001]=;
int i,Max=0;
for(i=1; i<=n; ++i)
{
++hash[a[i]];
if(hash[a[i]]>hash[Max]) Max=a[i];
}
最後輸出Max就好了

剛t415422663倒是提醒我了,如果要判斷眾數有多個,我可以把上面的程序稍改一下
int hash[10001]=;
int i,Max=-1;/*注意,這里把Max賦值為-1是為了防止數組a的元素個數為0時所有數據都被輸出*/
for(i=1; i<=n; ++i)
{
++hash[a[i]];
if(hash[a[i]]>Max]) Max=hash[a[i]];
}
//10000是數組a中可能出現的最大值,這個你可以自己改的
for(i=1; i<=10000; ++i)
if(hash[i]==Max) printf("%d\n",i);
你的串號我已經記下,採納後我會幫你製作

『貳』 C語言 如何編個程序求一組數的中位數和眾數

數組排序可以不用指針。你把數組定義成全局變數,比如說a[10001];然後調用我給你的快排程序就行了,這個程序可以背下來,很有用的。
void
qs(int
L,int
R)
{
int
i=L,j=R,mid=a[(L+R)/2],t;
while(i<j)
{
while(a[i]<mid)
++i;
while(a[j]>mid)
--j;
if(i<=j)
{
t=a[i];
a[i]=a[j];
a[j]=t;
++i;
--j;
}
}
if(i<R)
qs(i,R);
if(L<j)
qs(L,j);
}
排好序之後找中位數就好辦了。
至於眾數,我覺得最好的方法是用bfs。但這個對你來說難度有點大,我就給你寫一個hash表吧。還用上面的那個數組,且假定數組a中的最大值不超過10000,若超過,你把下面這個hash數組的范圍擴大就行了。
另外,設a中有n個元素,a從1開始計數(若從0開始,你改一下就好了)
int
hash[10001]={0};
int
i,Max=0;
for(i=1;
i<=n;
++i)
{
++hash[a[i]];
if(hash[a[i]]>hash[Max])
Max=a[i];
}
最後輸出Max就好了
剛t415422663倒是提醒我了,如果要判斷眾數有多個,我可以把上面的程序稍改一下
int
hash[10001]={0};
int
i,Max=-1;/*注意,這里把Max賦值為-1是為了防止數組a的元素個數為0時所有數據都被輸出*/
for(i=1;
i<=n;
++i)
{
++hash[a[i]];
if(hash[a[i]]>Max])
Max=hash[a[i]];
}
//10000是數組a中可能出現的最大值,這個你可以自己改的
for(i=1;
i<=10000;
++i)
if(hash[i]==Max)
printf("%d\n",i);

『叄』 C語言求眾數

#include<stdio.h>


int main()

{

int i,n,c,max=0,j,number;

int a[10];

scanf("%d",&n);

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

{

scanf("%d",&a[i]);

}

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

{

number=1;

for(j=0;j<n;j++)

{

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

{

number++;

}

if(max<number)

{

max=number;

c=a[i];

}

}

}

printf("該列數中眾數為: %d ",c);

return 0;


}

『肆』 如何用c語言求眾數

#include<stdio.h>

int main ()

{ int n,i,j,t,max=0,a[1000][2]={0};

scanf("%d",&n);

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

scanf("%d",&a[i][0]);

// printf("OK ");

for(i=0; i<n-1; i++)

for(j=0; j<n-1-i; j++)

if(a[j][0]>a[j+1][0])

{ t=a[j][0];

a[j][0]=a[j+1][0];

a[j+1][0]=t;

}

for(i=0; i<n;)

{ a[i][1]=1;

for(j=i+1; a[j][0]==a[i][0]; j++)

a[i][1]++;

if(a[i][1]>max)max=i;

i=j;

}

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

if(a[i][1]==a[max][1])

printf("%d ",a[i][0]);

return 0;

}

『伍』 用排序法排完序怎樣求眾數(C語言)

#include<stdio.h>

int mode(int a[],int n)

{ int k=1,i,j=0,max=1;

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

if(a[i]==a[i-1])

if(++k>max)

{ max=k;

j=i;

}

else k=1;

return a[j];

}

int main()

{ int a[]= {1,2,2,3,5,6,6,6,7,8,12};

printf("%d ",mode(a,11));

return 0;

}

『陸』 C語言求眾數問題

演算法很多。大致思路如下:
定義數據范圍:如0-100,
定義數組1:int a[101]//標保證任何數據都可以容納,並且初始化為0。
定義數組2:int data[n] //待處理數組,自己初始化。
代碼如下:
#include<stdio.h>
void main()
{
int a[101]={0};
int nMax = 0;
int data[50] = {1,3,4,2,13,4,2,1.....};//這個你自己初始化
for(int i=0;i<50;i++)
a[data[i]]++;
for(int n=0;n<101;n++)
{ if(nMax<a[n])

nMax = a[n];
}
for(int k=0;k<101;k++)
{
if(nMax == a[k])
printf("%4d,%4d\n",nMax,k);
}
}

『柒』 C語言程序設計:求眾數,中位數 重點看圖,會採納

這個很簡單啊,設置數組報存隨機生成的數,然後一個單循環求出各個數的重復次數。
或者選擇排序,連續相等數最多的就是眾數,中間那個數字就是中位數。

『捌』 C語言編程,求眾數

int
a[n],A[n];
不能這樣定義的吧。。。
A[a[i]]++;
這句有問題!
若輸入的a[i]大於n,則超出了A的下標范圍
訪問數組超范圍的下標,就會Runtime
Error。。。

『玖』 用C語言找眾數

1、先將數組a[N]排序(增序、降序都可以)

2、從a[i++]開始統計,若相等則計數器b[j++],如此重復。

3、在b[N]查找最大數max,並記錄max在b[N]中的索引imax

4、設置標志flag = 1,若滿足(b[i] == max && i != imax),則flag = 0

5、若falg = 0,返回-1,否則返回b[imax]

#include<stdio.h>
#include<stdlib.h>
#include<time.h>

constintN=10;

voidSort(inta[],intn){
inti,j,k,t;
for(i=0;i<n-1;++i){
k=i;
for(j=i+1;j<n;++j){
if(a[k]<a[j])k=j;
}
if(i!=k){
t=a[i];
a[i]=a[k];
a[k]=t;
}
}
}

voidShow(inta[],intn){
inti;
for(i=0;i<n;++i)
printf("%d",a[i]);
printf(" ");
}

intmain(){
inti,m,flag,imax;
inta[N],b[N];
srand((unsigned)time(NULL));
for(i=0;i<N;++i)//生成數組元素序列
a[i]=rand()%(1*N);
Sort(a,N);
Show(a,N);
b[0]=1;
for(i=1,m=0;i<N;++i){//統計各種大小數的個數
if(a[i]==a[i-1])++b[m];
elseb[++m]=1;
}
++m;
imax=0;
for(i=1;i<m;++i){//查找"眾數"的個數
if(b[i]>b[imax])
imax=i;
}
flag=1;
for(i=0;i<m&&flag;++i)//是否存在眾數?
if(b[i]==b[imax]&&i!=imax)
flag=0;
printf("%d ",flag?b[imax]:-1);
return0;
}
熱點內容
b樹磁碟存儲 發布:2025-01-31 19:42:53 瀏覽:837
聯想小新air15怎麼配置環境 發布:2025-01-31 19:06:57 瀏覽:968
什麼配置玩3a 發布:2025-01-31 19:05:22 瀏覽:586
phpoa系統 發布:2025-01-31 18:58:42 瀏覽:10
值e的編程 發布:2025-01-31 18:57:06 瀏覽:977
安卓手機的軟體認證在哪裡 發布:2025-01-31 18:57:01 瀏覽:535
android彈出來 發布:2025-01-31 18:56:56 瀏覽:232
辦公室白領新解壓方法 發布:2025-01-31 18:55:23 瀏覽:558
摩斯密碼短長是什麼意思 發布:2025-01-31 18:50:17 瀏覽:587
類的訪問修飾 發布:2025-01-31 18:42:46 瀏覽:933