2021-01-04

P20 2013(408统考真题)

用C语言统计一维数组中重复出现的数字的次数:

int A[n],B[n]=1;
for(int i=0;i<n;i++){
//如果A[i]出现两个相等的情况时,即就是B【该数】+1
B[A[i]]++;
//输出一维数组中每个元素的出现次数
//for(int i=0;i<n;i++)
//printf("%d出现的次数是%d\n",A[i],B[i]);
}

对于408统考题(2013统考真题)的第一种解法:

int Majority(int A[],int B[],int n){
//首先给B[n]数组中的元素全部赋值为1
//但是B[n]={0},这样可以全都赋值为0,但是用这种方法当赋值为其他的数时会出现
//B[0]=1,而数组中的其它值并不会被赋值为1,所以用这种办法不可以进行赋值,只能用循环来进行赋值。
//对数组B进行全体赋值为1
for(int i=0;i<n;i++){
B[i]=1;}

for(int i=0;i<n;i++){
//A[i]相当于从0开始存储,也就是说是B[0],B[1],B[2]中进行存储
B[A[i]]++;
//输出一维数组中每个元素的出现次数
//for(int i=0;i<n;i++)
//printf("%d出现的次数是%d\n",A[i],B[i]);
}
for(int j=0;j<n;j++){
if(B[j]>n/2)
printf(A[j]);
else
printf("-1");}

时间复杂度为O(n),空间复杂度为O(1)

对于408统考题(2013统考真题)的第二种解法(未运行过):

Search_main(int A[],int B[]){
for(int i=0;i<n;i++){
B[i]=1;
}
for(int i=0;i<n-1;i++){
for(int j=i+1;j<n;j++){
if(A[i]==A[j])
B[i]++;
}
}
int k=0;
while(k<n){
if(B[k]>n/2)
return A[k];
else
k++;
}
if(k>=n)
printf("-1");
}

时间复杂度O(n^2),空间复杂度O(1)

对于408统考题(2013统考真题)的第三种解法(正确答案):

int Majority(int A[],int n){
int i,c,count=1;
c=A[0];
for(int i=1;i<n;i++){
if(A[i]==c){
count++;}
else
 if(count>0)
count--;
else
c=A[i];
count=1;
}
}
if(count>0){
for(int i=0;i<n;i++){
if(A[i]==c)
count++
}
if(count>n/2)
printf("c");
else
printf("-1");

时间复杂度O(n),空间复杂度O(1).

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值