C語言深入淺出講解指針的使用_第1頁
C語言深入淺出講解指針的使用_第2頁
C語言深入淺出講解指針的使用_第3頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第C語言深入淺出講解指針的使用目錄一、利用指針倒序字符串二、題目實例三、總結

一、利用指針倒序字符串

void_reversal(char*left,char*right)

while(leftright)

chartmp=*left;

*left=*right;

*right=tmp;

left++;

right--;

通過上述代碼不難看出,left與right分別代表一個字符數(shù)組的首端和尾端,通過中間變量tmp進行首尾交換,left++中的left是char*類型,同時也可以看成為一維數(shù)組left[i++],因此,移動的原理就是通過++移向下一個元素位置所在的地址right同理可得是移向上一個元素位置所在的地址。

二、題目實例

對于一個較大的整數(shù)N(1=N=2,000,000,000)

比如980364535,我們常常需要一位一位數(shù)這個數(shù)字是幾位數(shù),但是如果在這個數(shù)字每三位加一個逗號,它會變得更加易于朗讀。因此,這個數(shù)字加上逗號成如下的模樣:980,364,535請寫一個程序幫她完成這件事情

輸入描述:

一行一個整數(shù)N

輸出描述:

一行一個字符串表示添加完逗號的結果

#define_CRT_SECURE_NO_WARNINGS1

#includestdio.h

#includestring.h

void_reversal(char*left,char*right)

while(leftright)

chartmp=*left;

*left=*right;

*right=tmp;

left++;

right--;

intmain()

chararr1[2000]={0};

gets_s(arr1);

intlen=strlen(arr1);

//翻轉字符串

_reversal(arr1,arr1+len-1);

chararr2[2000]={0};

char*pr1=arr1;

char*pr2=arr2;

inti=0;

while(i=len/3+1)

pr2[0]=pr1[0];

pr2[1]=pr1[1];

pr2[2]=pr1[2];

pr2[3]=',';

pr1+=3;

pr2+=4;

i++;

intlen1=strlen(arr2);

//翻轉字符串

_reversal(arr2,arr2+len1-1);

if(arr2[0]==',')

char*arr3=arr2+1;

printf("%s",arr3);

else

printf("%s",arr2);

return0;

}

就本題而言,為什么我們在插入的時候需要進行倒序呢,通過觀察我們發(fā)現(xiàn),插入的方式是從個位開始的,因此,從邏輯上我們需要將它進行倒序來滿足這個基本原理,不然可能會出現(xiàn)最后兩個數(shù)(或者是一個數(shù))前面會有逗號產生,這是規(guī)則不允許的。

三、總結

對于這個題本身而言,方法不止一種,通

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論