输入一组字符串,求出字符串中字符最长的数组字符串,输出它的首位置和数字个数及数字字符串。
例如:输入:today0119and20170120
输出:location:13,number:8,number strings:20170120
#include <stdio.h>
#include <string.h>
#define LEN 256 //定义一个字符数组的宽度
int main()
{
char s[LEN];
int i,max_len = 0,len = 0; // 定义计算数字字符串的变量
int loc,max_loc; //定义记录字符位置的变量
int flag = 0; // 标记字符是否为数字字符,flag=1时,是数字字符
printf("Please input the strings:\n");
scanf("%s",s);
for( i = 0;i < strlen(s);i ++)
{
if( isdigit( s[i] ) ) //判断字符是否是数字字符,isdigit()是判断数字字符的一个函数
{
if( flag == 0) //记录数字位置和标记符flag
{
len = 0;
loc = i;
flag = 1;
}
len++; //记录数字字符串的长度
}
else flag = 0;
if( len > max_len ) //找到最长的数字字符串,并记录它的位置和长度
{
max_len = len;
max_loc = loc;
}
}
printf(" location:%d, number:%d\n",max_loc + 1,max_len);
printf("number strings:");
for( i = max_loc;i < max_loc + max_len;i ++) //将最长的数字字符串输出
printf("%c",s[i]);
putchar('\n');
return 0;
}
运行结果示例:
Please input the strings:
today0119and20170120
location:13, number:8
number strings:20170120
每一个程序员都有自己写代码思路,而我只是写下了自己的想法。首先判断输入的字符是否是数字,用标记符flag做标记,并记录数字字符串的长度;接下来是找到最长的数字字符串;最后是输出位置、数字个数及这个数字字符串。