欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實(shí)現(xiàn)對輸入數(shù)字組進(jìn)行排序

 更新時(shí)間:2015年11月08日 15:07:13   投稿:hebedich  
這里給大家介紹的是通過某個(gè)方法實(shí)現(xiàn)判斷命令行中輸入的數(shù)字是幾個(gè),這樣再用冒泡法排序的時(shí)候就不用擔(dān)心輸入的是幾個(gè)數(shù)字,用到的知識主要是冒泡法排序

本是一個(gè)再簡單不了的功能,然后只是冒泡排序。可是我在交互輸入數(shù)列的時(shí)候,只用空格隔開然后回車,如果不限定數(shù)的個(gè)數(shù),用scanf并不能完成這個(gè)任務(wù),他循環(huán)獲取,到最后不能判斷獲取結(jié)束,而只能繼續(xù)等待輸入。

這個(gè)時(shí)候我自定義一個(gè)函數(shù),獲取緩存區(qū)中的數(shù)(空格分隔),如果輸入結(jié)束就返回一個(gè)特定的值,這個(gè)函數(shù)是用getchar循環(huán)嵌套實(shí)現(xiàn)的。本人新手,只能弄出這方法。歡迎各位大神指導(dǎo)。

maopao-complex.c

//比較復(fù)雜的數(shù)組接收方法,然后從大到小排序。VC環(huán)境
#include <stdio.h>
#include <stdlib.h>
int over=0;//用于讀取數(shù),如果讀取結(jié)束,為1
int main(void)
{
  //這一部分,接收數(shù)據(jù),判斷數(shù)據(jù)個(gè)數(shù)
  int getvalue(void); //函數(shù)原型。返回從緩沖區(qū)取得的數(shù),如果輸入結(jié)束,返回42949672
  int k;     //子循環(huán)臨時(shí)變量
  int a[100];   //建立100個(gè)數(shù)空間,可增縮范圍
  int num;    //輸入的個(gè)數(shù)
  int ifend = 1; //邏輯變量,控制while語句
  int i=0;    //通用計(jì)次臨時(shí)變量
  int value;   //元素值儲存地
  printf("請輸入任意數(shù)的序列,空格隔開:\n");
  while (ifend) 
  {
    value = getvalue();
    if(value == 42949672)
      ifend = 0;
    else
    {
      a[i] = value;
      i++;
    }
  } //結(jié)束后,i為數(shù)組成員個(gè)數(shù)
  num = i;
  //開始排序
  for (i=0; i < num-1; i++)  //循環(huán)8次,第n次把第n位以后的數(shù)的最大值放第n個(gè)
  {
    for(k=i+1; k<num; k++)  //用k表示后面的各位,遞增。
    {
      if (a[i] < a[k]) //選大數(shù),放第n位
      {
        a[i] = a[i] + a[k];
        a[k] = a[i] - a[k];
        a[i] = a[i] - a[k];//以上三步,把較大值放到a[i]
      }
    }
  }
   
  //輸出新數(shù)組
  printf("排序后:\n");
   
  for (i=0; i<num; i++)
  {
    printf("%d ",a[i]); 
  }
  printf("\n");
 
  return 0;
}
 
 
int getvalue(void)
{
  char a[16]={0};   //數(shù)字接收臨時(shí)數(shù)組
  int k;
  int value=0;
  char temp;
  int last = 1;
  int ifend = 1;
  int i = 0; //用來定位數(shù)組
  if (over == 1)
  {
    ifend = 0;
    return (42949672);
  }
  temp = getchar();
  while(ifend)
  {
    if (temp == 32)//接收結(jié)束,把臨時(shí)數(shù)組轉(zhuǎn)化成數(shù)字
    {
      value = atoi(a);
      ifend = 0;
    }
    else if (temp == '\n')//緩沖區(qū)已無數(shù)值
    {
      value = atoi(a);
      over = 1;
      ifend = 0;
    }
    else  //輸入有效數(shù)值
    {
      if (temp == '-')
      {
        last = -1;
      }
      else
      {
        a[i] = temp;
        i++;
      }
      temp = getchar();
    }
  }
 
  value*=last;
  return (value);
}

下面是一個(gè)簡單的冒泡排序:

#include <iostream>
using namespace std;
void BubbleSort (int* pData,int Count)
{
 int iTemp;
 for(int i=1; i<Count; i++)
 {
  for (int j=Count-1; j>=1; j--)
  {
  if (pData[j]<pData[j-1])
  {
   iTemp=pData[j-1];
   pData[j-1]=pData[j];
   pData[j]=iTemp;
  }
  }
 }
}
void main()
{
 
 int data[]= {10,9,8,7,6,5,4}
 BubbleSort(data,7);
 for (int i=0;i<7;i++)
 cout<<data[i]<<" ";
 cout<<"\n";
}

相關(guān)文章

  • Visual C++中Tab View的多種實(shí)現(xiàn)方法

    Visual C++中Tab View的多種實(shí)現(xiàn)方法

    這篇文章主要介紹了Visual C++中Tab View的多種實(shí)現(xiàn)方法,包括了CTabCtrl控件、CSheetCtrl標(biāo)簽選擇窗口以及靜態(tài)分割窗口等實(shí)現(xiàn)Tab View的方法,需要的朋友可以參考下
    2014-10-10
  • C++ opencv實(shí)現(xiàn)車道線識別

    C++ opencv實(shí)現(xiàn)車道線識別

    這篇文章主要為大家詳細(xì)介紹了C++ opencv實(shí)現(xiàn)車道線識別,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • C語言if選擇結(jié)構(gòu)語句詳解

    C語言if選擇結(jié)構(gòu)語句詳解

    大家好,本篇文章主要講的是C語言if選擇結(jié)構(gòu)語句詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • C++基本算法思想之窮舉法

    C++基本算法思想之窮舉法

    在使用窮舉法時(shí),需要明確問題的答案的范圍,這樣才可以在指定的范圍內(nèi)搜索答案。指定范圍之后,就可以使用循環(huán)語句和條件語句逐步驗(yàn)證候選答案的正確性,從而得到需要的正確答案
    2013-10-10
  • C語言求連續(xù)最大子數(shù)組和的方法

    C語言求連續(xù)最大子數(shù)組和的方法

    這篇文章主要介紹了C語言求連續(xù)最大子數(shù)組和的方法,包含了數(shù)組的常見操作及相關(guān)技巧,需要的朋友可以參考下
    2014-09-09
  • C++?opencv圖像處理使用cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換

    C++?opencv圖像處理使用cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換

    這篇文章主要為大家介紹了C++?opencv圖像處理cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換的實(shí)現(xiàn)示例代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • C++中如何修改const變量你知道嗎

    C++中如何修改const變量你知道嗎

    這篇文章主要為大家詳細(xì)介紹了C++修改const變量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C/C++新建注冊表項(xiàng)的代碼示例

    C/C++新建注冊表項(xiàng)的代碼示例

    今天小編就為大家分享一篇關(guān)于C/C++新建注冊表項(xiàng)的代碼示例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • c++字符串char[]數(shù)組分割split問題

    c++字符串char[]數(shù)組分割split問題

    這篇文章主要介紹了c++字符串char[]數(shù)組分割split問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • C語言簡明講解快速排序的應(yīng)用

    C語言簡明講解快速排序的應(yīng)用

    快速排序由于排序效率在同為O(N*logN)的幾種排序方法中效率較高,因此經(jīng)常被采用,再加上快速排序思想----分治法也確實(shí)實(shí)用,因此很多軟件公司的筆試面試,包括像騰訊,微軟等知名IT公司都喜歡考這個(gè),還有大大小的程序方面的考試如軟考,考研中也常常出現(xiàn)快速排序的身影
    2022-05-05

最新評論