溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

C語(yǔ)言中的字符類(lèi)型怎么利用scanf輸入

發(fā)布時(shí)間:2020-12-10 14:13:33 來(lái)源:億速云 閱讀:291 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

C語(yǔ)言中的字符類(lèi)型怎么利用scanf輸入?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

昨天用C編程,遇到一個(gè)關(guān)于scanf的細(xì)節(jié)問(wèn)題,假如運(yùn)行如下程序:

#include<stdio.h>
int main()
{
 char ch2,ch3;
 printf("Input for ch2:/n");
 scanf("%c",&ch2);
 printf("ch2=%c/n",ch2);
 printf("Input for ch3:/n");
 scanf("%c",&ch3);
 printf("ch3=%c/n",ch3);
}

表面上看這段程序是沒(méi)有錯(cuò)的,也可以運(yùn)行,但運(yùn)行過(guò)程中到第二個(gè)scanf輸入值給ch3時(shí),程序不會(huì)停止,而是直接運(yùn)行到最后一個(gè)printf !

為什么?當(dāng)時(shí)百思不得其解。。。

今天上網(wǎng)查了下才知道,原來(lái)scanf是從標(biāo)準(zhǔn)輸入緩沖區(qū)中讀取輸入的數(shù)據(jù),而%c的字符輸入格式會(huì)接收回車(chē)字符,在輸入第一個(gè)scanf時(shí)輸入字符后按 回車(chē)結(jié)束,輸入緩沖中保存了這個(gè)回車(chē)符,遇到第二個(gè)scanf時(shí),它自動(dòng)把這個(gè)回車(chē)符賦給了ch3。

而如果第二個(gè)scanf的輸入格式不是%c時(shí),由于格 式不匹配,這個(gè)回車(chē)符會(huì)被自動(dòng)忽略,所以只有在連續(xù)輸入兩個(gè)%c的格式時(shí)才會(huì)出現(xiàn)這樣的問(wèn)題!

解決辦法:(二辦法任選其一)

1。清空輸入緩沖區(qū)

第一個(gè)scanf后加入語(yǔ)句:

fflush(stdin); //C語(yǔ)言清空輸入緩沖區(qū)函數(shù)

2。格式控制中加入空格

將第二個(gè)scanf改為:

scanf(" %c",&ch3);//在%號(hào)前面加一個(gè)空格

scanf格式輸入時(shí)要求輸入格式與格式控制符中的完全一樣(如:scanf("abcd%c",&ch);輸入時(shí)必須輸入abcde,ch得到的值為e)空格可以抵消前面輸入的回車(chē)符。

補(bǔ)充知識(shí):利用C語(yǔ)言實(shí)現(xiàn):輸入兩個(gè)字符串,統(tǒng)計(jì)一個(gè)字符串在另一個(gè)字符串中出現(xiàn)的次數(shù)。

輸入兩個(gè)字符串,統(tǒng)計(jì)一個(gè)字符串在另一個(gè)字符串中出現(xiàn)的次數(shù)

例如,asdfgasfgasf,as,則輸出3

編程環(huán)境為codeblocks,編譯器是GUN-GCC,操作系統(tǒng)是win7-64位

分析:此代碼主要運(yùn)用了一個(gè)算法,是字符串匹配的樸素模式匹配算法。看懂算法之后再來(lái)讀代碼就沒(méi)有什么壓力了。

代碼如下:

#include <stdio.h>
#include <stdlib.h>
int main()
{
 char S[100],T[20];
 char ch2,ch3;
 printf("請(qǐng)輸入主字符串:\n");
 ch2=getchar();
 int i=0;
 while(ch2!='\n')
 {
  S[i]=ch2;
  i++;
  ch2=getchar();
 }
 
 printf("請(qǐng)輸入要篩選的字符串:\n");
 ch3=getchar();
 int j=0;
 while(ch3!='\n')
 {
  T[j]=ch3;
  j++;
  ch3=getchar();
 }
 
 int m,n;//m為S的下標(biāo),n為T(mén)的下標(biāo)
 m=0;
 n=0;
 int num=0;//num用于記錄選定單詞出現(xiàn)的次數(shù)
 while(m<=i&&n<=j)
 {
  if(S[m]==T[n])
  {
   m++;
   n++;
  }
  else
  {
   m=m-n+1;
   n=0;
  }
  if(n==j)
  {
   num++;
  }
 }
 if(m==i+1)
  {
   printf("出現(xiàn)的次數(shù)是%d",num);
  }
}

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI