云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > C语言各种排序源代码

C语言各种排序源代码

  • 62 次阅读
  • 3 次下载
  • 2025/5/2 13:40:50

427. 428. void paixu_dui(int* p,int leng,int (* cmp)(const

void* a,const void* b)) //堆排序 429. { 430. int data; 431. for(int i=leng/2;i>=0;i--) 432. dui_jian(p,i,leng,cmp); 433. //建堆 434. 435. for(int i=leng-1;i>0;i--) 436. { 437. data=p[0]; 438. p[0]=p[i]; 439. p[i]=data; 440. dui_jian(p,0,i-1,cmp); 441. } 442. //最后一个和第一个交换 443. //重新调整堆 444. 445. return; 446. } 447. 448. void dui_jian(int* p,int s,int leng,int (*

cmp)(const void* a,const void* b)) //堆排序,建堆 449. { 450. int data=p[s]; 451. 452. for(int i=2*s;icmp((p+i),(p+i+1))) 455. i++; 456. if(0<=cmp(&data,(p+i))) 457. break; 458. p[s]=p[i]; 459. s=i; 460. } 461. p[s]=data; 462. //使堆顶为最小或最大值 463. 464. return; 465. } 466. 467. void paixu_geshibai(int* p,int leng,int (*

cmp)(const void* a,const void* b))//基数排序

468. { 469. int max=1; 470. int x=1; 471. int n=0; 472. int p_index=0; 473. int* p_data[10]; 474. int data_index[10]={0}; 475. bool max_xunzhao=true; 476. 477. bool shunxu=true; 478. int a=1; 479. int b=2; 480. if(0

一次就可以了 496. 497. if(x>p[i]) 498. p_data[0][data_in

dex[0]++]=p[i]; //小于x就不用计算n的值了,因为计算了也是0 499. else 500. { 501. n=(p[i]/x);

//计算基数 502. p_data[n][data_index[

n]++]=p[i]; //放到相应的空间里 503. } 504. } 505. 506. if(shunxu)

507. for(int i=0;i<10;i++) 508. { 509. for(int

j=0;j

_data[i][j]; 511. data_index[i]=0; 512. } 513. else 514. for(int i=9;i>=0;i--) 515. { 516. for(int

j=0;j

_data[i][j]; 518. data_index[i]=0; 519. } 520. //上面是看升序还降序,决定是++

还-- 521. //把空间里的数据按顺序放回p 522. 523. x*=10; 524. p_index=0; 525. max_xunzhao=false; 526. } 527. return; 528. } 529. 530. int paixu_fangfa(const void* a,const void* b) //

排序方法,是降序还升序 531. { 532. return *(int*)a-*(int*)b; 533. }

复制代码

搜索更多关于: C语言各种排序源代码 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

427. 428. void paixu_dui(int* p,int leng,int (* cmp)(const void* a,const void* b)) //堆排序 429. { 430. int data; 431. for(int i=leng/2;i>=0;i--) 432. dui_jian(p,i,leng,cmp); 433. //建堆 434. 435. for(int i=leng-1;i>0;i--) 436. { 437. data=p[0]; 438. p[0]=p[i]; 439. p[i]=data; 440. dui_ji

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com