设计C语言程序,用一维数组输入N个整数,将这n个整数按从大到小排列 急!!C语言:一维数组,输入一组整数然后按照大小排列

C\u8bed\u8a00\u7f16\u7a0b\uff0c\u4ece\u952e\u76d8\u4e0a\u8f93\u5165n\uff08n<=20)\u4e2a\u6574\u6570\u5b58\u5165\u4e00\u7ef4\u6570\u7ec4

#include
void negasort(int *array,int n);//\u9006\u5e8f\u5b58\u653e\u51fd\u6570
int main()
{
int arry[20];
int n;
printf("\u8bf7\u8f93\u5165\u6570\u7ec4\u5143\u7d20\u4e2a\u6570\uff1a");
scanf("%d",&n);
printf("\u8bf7\u8f93\u5165\u6570\u7ec4\u5143\u7d20\uff1a");
for(int i=0;i<n;i++)
scanf("%d",arry+i);
negasort(arry,n);//\u8c03\u7528\u9006\u5e8f\u5b58\u653e\u51fd\u6570
for(int j=0;j<n;j++)
printf("%d\t",*(arry+j));
}
void negasort(int *arry,int n)
{
int temp;
int m=n/2;
for(int k=0;k<m;k++)
{
temp=*(arry+k);
*(arry+k)=*(arry+n-1-k);
*(arry+n-1-k)=temp;
}
}

#include int main(){int n;// \u6570\u5b57\u4e2a\u6570printf("number count: ");scanf("%d", &n);int *p = (int *)malloc(n*sizeof(int));// \u5206\u914d\u6570\u7ec4\u7a7a\u95f4for(int i=0;i<n;i++){// \u6328\u4e2a\u8f93\u5165\u6570\u5b57printf("number %d: ", i+1);scanf("%d", p+i);}for(int i=0;i<n;i++)// \u8f93\u51fa\u6392\u5e8f\u524d\u6570\u7ec4printf("%d ", p[i]);printf("\n");for(int i=0;i<n-1;i++){// \u9009\u62e9\u6392\u5e8fint min = i;for(int j=i+1;j<n;j++)// \u627e\u5230\u6700\u5c0f\u7684if(p[j]<p[min])min = j;int tmp = p[i];// \u4ea4\u6362p[i] = p[min];p[min] = tmp;for(int i=0;i<n;i++)// \u8f93\u51fa\u6392\u5e8f\u7684\u6b65\u9aa4printf("%d ", p[i]);printf("\n");}return 0;}
\u8f93\u5165\u8f93\u51fa\uff1a
number count: 5\u2199
number 1: 6\u2199
number 2: 12\u2199
number 3: 5\u2199
number 4: 97\u2199
number 5: 1\u2199
6 12 5 97 1
1 12 5 97 6
1 5 12 97 6
1 5 6 97 12
1 5 6 12 97

给你看看C语言的三种排序方法吧,这是我们老师给总结的,你看懂后就自己在写这个程序吧!

一、冒泡法(起泡法)
算法要求:用起泡法对10个整数按升序排序。
算法分析:如果有n个数,则要进行n-1趟比较。在第1趟比较中要进行n-1次相邻元素的两两比较,在第j趟比较中要进行n-j次两两比较。比较的顺序从前往后,经过一趟比较后,将最值沉底(换到最后一个元素位置),最大值沉底为升序,最小值沉底为降序。
算法源代码:
# include <stdio.h>
main()
{
int a[10],i,j,t;
printf("Please input 10 numbers: ");
/*输入源数据*/
for(i=0;i<10;i++)
scanf("%d",&a[i]);
/*排序*/
for(j=0;j<9;j++) /*外循环控制排序趟数,n个数排n-1趟*/
for(i=0;i<9-j;i++) /*内循环每趟比较的次数,第j趟比较n-j次*/
if(a[i]>a[i+1]) /*相邻元素比较,逆序则交换*/
{ t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
/*输出排序结果*/
printf("The sorted numbers: ");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
}
算法特点:相邻元素两两比较,每趟将最值沉底即可确定一个数在结果的位置,确定元素位置的顺序是从后往前,其余元素可能作相对位置的调整。可以进行升序或降序排序。
二、选择法
算法要求:用选择法对10个整数按降序排序。
算法分析:每趟选出一个最值和无序序列的第一个数交换,n个数共选n-1趟。第i趟假设i为最值下标,然后将最值和i+1至最后一个数比较,找出最值的下标,若最值下标不为初设值,则将最值元素和下标为i的元素交换。
算法源代码:
# include <stdio.h>
main()
{
int a[10],i,j,k,t,n=10;
printf("Please input 10 numbers:");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<n-1;i++) /*外循环控制趟数,n个数选n-1趟*/
{
k=i; /*假设当前趟的第一个数为最值,记在k中 */
for(j=i+1;j<n;j++) /*从下一个数到最后一个数之间找最值*/
if(a[k]<a[j]) /*若其后有比最值更大的*/
k=j; /*则将其下标记在k中*/
if(k!=i) /*若k不为最初的i值,说明在其后找到比其更大的数*/
{ t=a[k]; a[k]=a[i]; a[i]=t; } /*则交换最值和当前序列的第一个数*/
}
printf("The sorted numbers: ");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
}
算法特点:每趟是选出一个最值确定其在结果序列中的位置,确定元素的位置是从前往后,而每趟最多进行一次交换,其余元素的相对位置不变。可进行降序排序或升序排序。
三、插入法
算法要求:用插入排序法对10个整数进行降序排序。
算法分析:将序列分为有序序列和无序列,依次从无序序列中取出元素值插入到有序序列的合适位置。初始是有序序列中只有第一个数,其余n-1个数组成无序序列,则n个数需进n-1次插入。寻找在有序序列中插入位置可以从有序序列的最后一个数往前找,在未找到插入点之前可以同时向后移动元素,为插入元素准备空间。
算法源代码:
# include <stdio.h>
main()
{
int a[10],i,j,t;
printf("Please input 10 numbers: ");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=1;i<10;i++) /*外循环控制趟数,n个数从第2个数开始到最后共进行n-1次插入*/
{
t=a[i]; /*将待插入数暂存于变量t中*/
for( j=i-1 ; j>=0 && t>a[j] ; j-- ) /*在有序序列(下标0 ~ i-1)中寻找插入位置*/
a[j+1]=a[j]; /*若未找到插入位置,则当前元素后移一个位置*/
a[j+1]=t; /*找到插入位置,完成插入*/
}
printf("The sorted numbers: ");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
}
算法特点:每趟从无序序列中取出第一个数插入到有序序列的合适位置,元素的最终位置在最后一趟插入后才能确定位置。也可是先用循环查找插入位置(可从前往后或从后往前),再将插入位置之后的元素(有序列中)逐个后移一个位置,最后完成插入。该算法的特点是在寻找插入位置的同时完成元素的移动。因为元素的移动必须从后往前,则可将两个操作结合在一起完成,提高算法效率。仍可进行升序或降序排序。

这应该会对你很有用的,好好学,把它弄懂!祝你好运!

排序:
#include<stdio.h>
void main()
{
int i,j,m,N,a[99];
scanf("%d",&N);//输入元素个数
for(i=0;i<N;i++)
scanf("%d",&a[i]);
for(j=1;j<=N-1;j++)
for(i=0;i<N-j;i++)
if(a[i]>a[i+1])
{
m=a[i];
a[i]=a[i+1];
a[i+1]=m;
}
for(i=0;i<N;i++)
printf("%5d",a[i]);
printf("\n");
}

#include <stdio.h>
void sort(int *items, int count)
{ int a,b,t;
for(a=1;a<count;++a)
for(b=count-1;b>=a;--b)
if(items[b-1]>items[b])
{ t=items[b-1];
items[b-1]=items[b];
items[b]=t;
}
}
int main()
{ #define N 10
int a[N],i;
for(i=0;i<N;i++)scanf("%d",&a[i]);
sort(a,N);
for(i=0;i<N;i++)printf("%d ",a[i]);
return 0;
}

#include<stdio.h>
#define N 5
int main()
{
int i,j;
int a[N];
int temp;
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}
for(i =0;i<N -1;i++)
{
for(j =i+1;j<N ;j++)
if(a[i]<a[j])
{
temp =a[i];
a[i] =a[j];
a[j] = temp;
}
}
for(i =0;i<N;i++)
{
printf(" %d",a[i]);
}
return 0;

}

  • C璇█:鍒涘缓涓涓涓缁(int)鏁扮粍(缁存暟涓6),杈撳叆鏁扮粍鍏冪礌,骞惰緭鍑烘暟缁勫厓绱犱腑 ...
    绛旓細int main(){ int a[6],i,j,temp;printf("杈撳叆6涓暟锛歕n");for(i=0;i<6;i++)scanf("%d",&a[i]);for(i=0;i<6;i++)for(j=i+1;j<6;j++)if(a[i]
  • 璁捐C璇█绋嬪簭,鐢ㄤ竴缁存暟缁勮緭鍏N涓暣鏁,灏嗚繖n涓暣鏁版寜浠庡ぇ鍒板皬鎺掑垪_鐧惧害...
    绛旓細绠楁硶鍒嗘瀽锛氬皢搴忓垪鍒嗕负鏈夊簭搴忓垪鍜屾棤搴忓垪锛屼緷娆′粠鏃犲簭搴忓垪涓彇鍑哄厓绱犲兼彃鍏ュ埌鏈夊簭搴忓垪鐨勫悎閫備綅缃傚垵濮嬫槸鏈夊簭搴忓垪涓彧鏈夌涓涓暟锛屽叾浣檔-1涓鏁扮粍鎴愭棤搴忓簭鍒楋紝鍒檔涓暟闇杩沶-1娆℃彃鍏ャ傚鎵惧湪鏈夊簭搴忓垪涓彃鍏ヤ綅缃彲浠ヤ粠鏈夊簭搴忓垪鐨勬渶鍚庝竴涓暟寰鍓嶆壘锛屽湪鏈壘鍒版彃鍏ョ偣涔嬪墠鍙互鍚屾椂鍚戝悗绉诲姩鍏冪礌锛屼负鎻掑叆鍏冪礌...
  • 濡備綍鍦C璇█涓杈撳叆涓缁存暟缁?
    绛旓細1銆杈撳叆鏁扮粍闇瑕佷娇鐢ㄦ寚閽堣幏鍙栧湴鍧鍚庯紝灏辫兘瀵瑰緱鍒扮殑鏁扮粍灏辫鎿嶄綔浜嗐傞鍏堟墦寮DEV C++杞欢锛屾柊寤轰竴涓┖鐧界殑C璇█鏂囦欢锛2銆杈撳叆绋嬪簭鐨勬簮鐮侊紝鍏堝畾涔変竴涓暣鍨嬫暟缁勨渁[5]鈥锛岄噰鐢scanf璇彞杈撳叆鏁扮粍涓殑姣忎釜鍏冪礌锛岃繖閲屼娇鐢ㄦ寚閽堟潵瀵硅緭鍏ョ殑鏁板瓧杩涜璁块棶锛岃鍏堢粰杈撳叆鐨勬瘡涓涓暟瀛楃粰浜堝畠鐨勫湴鍧锛屼究浜庤闂紝鏈鍚庢嬁寰楀埌...
  • C璇█濡備綍瀹炵幇涓涓涓缁存暟缁鐨杈撳叆杈撳嚭?
    绛旓細C璇█绋嬪簭濡備笅锛歩nclude <stdio.h> void fun(int a[],int n,int *k){ int i,maxxr,j;maxxr=a[0];for(i=0;i<n;i++){ if(maxxr<a[i]){ maxxr=a[i];} } for(i=0;i<n;i++){ if(maxxr==a[i]){ j=i;break;} } k=j;} int main(void){ int a[10]={ 876,...
  • 鐢C璇█缂栧啓:缁涓缁存暟缁勮緭鍏浠绘剰n涓暟,鍋囪杈撳叆6涓暟鏄7,4,8,9,1...
    绛旓細//绋嬪簭杩愯缁撴灉濡備笅鍥撅紝鏈夐棶棰樺彲杩介棶銆俰nclude <stdio.h>int main(){ int n,k; int a[10]; scanf("%d",&n); for(int i=0;i<n;i++) { scanf("%d",&a[i]); } printf("\n"); for(int i=0;i<n;i++) { k=n-1-i; for(int j=...
  • 鐢C璇█鎬庝箞缂栧啓绋嬪簭瀹炵幇浠庨敭鐩杈撳叆鏁板
    绛旓細include"stdio.h"//浠庨敭鐩杈撳叆10涓暟瀛樺叆涓缁存暟缁勶紝姹傝繖10涓暟涓殑鏈澶у煎拰鏈灏忓煎苟杈撳嚭 intmain(){ inti;floatmax,min,num[10];printf("璇疯緭鍏10涓暟锛屾瘡杈撳叆涓涓暟鎸夊洖杞﹂敭缁撴潫:\n");for(i=0;i<10;i++){ scanf("%f",&num[i]);} max=min=num[0];for(i=1;i<10;i++){ ...
  • c璇█,缂栧啓涓涓绋嬪簭鍙互杈撳叆浠绘剰涓涓涓缁存暟缁,浠g爜
    绛旓細浣犲ソ锛屼綘鐨勬剰鎬濇槸閫氳繃閿洏杈撳叆鏁扮粍鐨勫厓绱狅紝鐒跺悗灏嗘暟缁勮緭鍑哄悧锛熷鏋滄槸杩欐牱鐨勮瘽锛岄偅涔堟湁涓ょ鏂规硶銆傜涓绉嶏細鍦ㄨ緭鍏ユ暟缁勫厓绱犱箣鍓嶏紝寰楀厛杈撳叆鏁扮粍鐨勯暱搴︺傜浜岀锛氫娇鐢ㄩ摼琛ㄣ傝繖鏃跺氨涓嶉渶瑕佹寚瀹氭暟缁勭殑闀垮害 浜嗐傛垜鍏堢‘瀹氫竴涓嬫槸涓嶆槸杩欐牱锛屽鏋滀綘纭疄鏈夎繖涓渶姹傜殑璇濓紝鎴戝啀缂栧啓浠g爜锛屽ソ鍚楋紵
  • 缂栧啓涓涓c绋嬪簭,浠庨敭鐩杈撳叆涓涓暱搴︿负10鐨勫疄鍨涓缁存暟缁,鐒跺悗椤哄簭杈撳嚭...
    绛旓細C璇█绋嬪簭锛歩nclude "stdio.h"#define N 10void main(){ double arr[N];int i, k;double max;printf("璇杈撳叆 %d 涓疄鏁帮細", N);for(i=0; i<N; i++)scanf("%lf", &arr[i]);max = arr[0];for(i=1; i<N; i++)if(arr[i] > max){max = arr[i];k = i;}printf("...
  • C璇█ 璇鐢ㄤ竴缁存暟缁瑙g瓟
    绛旓細1.#include <stdio.h>struct Day{ int year; int mon; int day;}days;void main (){ int i,total = 0; int month[12] = {31,28,31,30,31,30,31,31,30,31,30,31}; printf ("杈撳叆骞淬佹湀銆佹棩(绌烘牸闅斿紑):\n"); scanf ("%d%d%d",&days.year,&days.mon,&days.day); for ...
  • 鐢c璇█缂栧啓涓涓畻娉,鍏跺姛鑳芥槸缁涓缁存暟缁a杈撳叆浠绘剰6涓暣鏁,鍋囪涓:574...
    绛旓細int main(){ int arr[6];//瀹氫箟鏁扮粍 int i=0,j=0;printf("input numbers\n");for (i=0;i<6;i++){ scanf("%d",&arr[i]);//璧嬪 } for (i=0;i<6;i++){ printf("%d ",arr[i]);//杈撳嚭鎵杈撳叆鐨勫 } printf("\n");for (j=0;j<6;j++)//寰幆鎵ц6娆 { for (...
  • 扩展阅读:c语言一维数组相加 ... 一维数组的理解 ... 一维数组的使用 ... c#简单程序实例 ... 数组的第一维指什么 ... c语言一维数组输入 ... 对一维数组进行排序 ... 一维数组格式 ... 一维数组是什么样的 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网