統計字符串單詞個數
【問題描述】統計字符串str中單詞的個數。單詞之間以空格,逗號,句號作分隔,數字也看做單詞。單詞之間可能不止一個分隔符。
【輸入形式】從標準輸入中輸入一組字符串
【輸出形式】輸出單詞個數
【樣例輸入】It's 10:10 o'clock ,I am late.
【樣例輸出】6
#include<stdio.h>
#include<string.h>
int main()
{
int i,le,flag=0,num=0;
char s[100];
gets(s);
le=strlen(s);
for(i=0;i<le;i++)
{
if(s[i]==' '||s[i]==','||s[i]=='.')
flag=0;
else
{
flag ++ ;
if(flag == 1)
num ++ ;
}
}
printf("%d", num);
}
分析
首先使用gets得到字符串s,遍歷其每一個字符,如果爲分隔符,那麼設flag爲0,否則flag++
所以我們可以分析得到,如果當前的flag=0,那麼上一個字符爲分隔符(此時不一定單詞+1,因爲可能出現多個空格並列)
如果flag=1,表示上一個字符爲一個單詞的第一個字母(就是說一個單詞已經開始了,num++)
若flag=8,表示上一個字符爲一個單詞的第8個字母
字符交叉拼接
問題描述】
編寫函數void fun(char *s1,char *s2),實現字符串s1與s2的交叉連接,連接後得到的新字符串放在s1中。如輸入abc<CR>12345<CR>,輸出a1b2c345,若輸入abcde<CR>123<CR>,則輸出a1b2c3de。
#include<stdio.h>
#include<string.h>
void fun(char *s1,char *s2)
{
}
int main()
{
char a[100],b[100];
void fun(char *,char *);
printf("Input string 1:");
gets(a);
printf("Input string 2:");
gets(b);
fun(a,b);
puts(a);
return 0;
}
【輸入形式】輸入2個字符串
【輸出形式】輸出交叉連接後的字符串
【樣例輸入】
Input string 1:abcdefg
Input string 2:123
【樣例輸出】a1b2c3defg
#include<stdio.h>
#include<string.h>
void fun(char *s1,char *s2)
{
int i, j, lmin;
int l1 = strlen(s1);
int l2 = strlen(s2);
if(l1 < l2)
lmin = l1;
else
lmin = l2;
char s3[520];
for(i = 0; i < l1; i++) // 將s1複製到s3裏,以後就用s3當s1
{
s3[i] = s1[i];
}
for(i = 0; i < 2*lmin; i++) // 處理前面交錯的部分
{
if(i%2 == 0)
{
int p = i/2 ;
s1[i] = s3[p] ;
}
if(i%2 == 1)
{
int p = (i-1)/2;
s1[i] = s2[p] ;
}
}
if(l1 < l2) // 處理後面的尾巴
{
for(j = (i-1)/2+1; j < l2; j++)
{
s1[i++] = s2[j];
}
s1[i] = '\0'; // 不加此項結尾符,puts會將後續亂碼輸出
}
else if(l1 > l2)
{
for(j = i/2; j < l1; j++)
{
s1[i++] = s3[j];
}
s1[i] = '\0';
}
}
int main()
{
char a[100],b[100];
void fun(char *,char *);
printf("Input string 1:");
gets(a);
printf("Input string 2:");
gets(b);
fun(a,b);
puts(a);
return 0;
}
分析
這裏採取簡單粗暴的直接做法。
即先把兩條字符串前n個,你一個我一個的交錯起來,得到一個2n的混合串,然後將較長的那個直接加在後面作爲尾巴