本文主要是介绍linux下的c语言入门 - day6,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这一章是字符串和文本,虽然之前有提到过,但这次是系统化的课本学习,还是要好好学一下。
c中的字符串总是以\0结尾,所以字符串的长度永远比字符串中的字符数多1.而且在语句中只要遇到第一个\0时候,就表示字符串结束了。
接下来介绍一下多个字符串有关的库函数:
1.strcpy(string2,string2);
这是用来复制字符串的,将第二个参数指定的字符串复制到第一个参数指定的字符串当中。还有个类似的库函数是strncpy(destination,source,n),这个函数将一个字符串中的前n个字符赋值到另一个字符串当中。第一个参数是目标字符串,第二个参数是源字符串,打三个参数是一个size_t类型的整数,他制定了要复制的字符书。
2.strlen(str)
这是确定字符串的长度。
3.strcat(str1,str2)
使用库函数连接字符串,这个函数将用str2复制到str1的末尾。这可以大大降低难度。
strcmp(str1,str2)
比较两个字符串,返回一个小于,大于或等于0的int值,分别对应str1小于,大于,等于str2.
strstr(str, c)
首先是要把<string.h>头文件包含在文件里,函数在字符中搜索给定的字符。她的第一个参数是要搜索的字符串(是char数组的地址),第二个就是要查找的字符。这个函数会从字符串的开头开始搜索,返回在字符串中找到第一个给定字符的地址。有时候需要在字符串中查找子字符串。所以strstr()函数是这个头文件中声明的所有搜索函数中最有用的函数,他查找一个子字符串,返回找到的第一个子字符串的位置指针。如果找不到匹配的子字符串,就返回NULL。所以如果返回值不是NULL,就说明这个函数找到了所需的子字符串。
isalpha(),isdigit()
这两个函数中的参数是要测试的字符。如果这个字符在该函数的测试内容范围之内,所有这些函数都返回一个非零的int值,否则,返回0.这里注意,用了get()函数作为接受键盘的输入数函数时,有个优点:可以从键盘读入所有的字符(包括空白),直到按下回车键为止。而还有一个类似的函数fgets()他们之间的异同点是:他们都读取一个换行符来结束过程,但在输入换行符时,fgets()会存储'\n'字符,而gets()不会。因此,如果从见哦按双读取字符串,fgets()读取的字符串比gets()读取的字符串多一个字符。
toupper(),tolower()
这是<ctype.h>所包含的两个转换函数,是将大小写字母相互转化。eg:buffer[i] = toupper(buffer[i])
最后要给一个大程序,就是从键盘上输入一段任意长度的文本,确定该文本中每个单词的出现频率(忽略大小写),现在编写的有点复杂,不过在后续的学习当中会学到可以简化他的知识。
#include#include#include#include#define TEXTLEN 10000
#define BUFFERSIZE 100
#define MAXWORDS 500
#define WORDLEN 15
int main()
{
char text[TEXTLEN + 1];
char buffer[BUFFERSIZE];
char endstr[] = "*\n";
int i = 0;
const char space = ' ';
const char quote = '\'';
char words[MAXWORDS][WORDLEN + 1];
int nword[MAXWORDS];
char word[WORDLEN + 1];
int wordlen = 0;
int wordcount = 0;
printf("Enter text on an arbitrary number of lines.");
printf("\n Enter a line containing just an asterisk to end input: \n\n");
while(true)
{
if(!strcmp(fgets(buffer,BUFFERSIZE,stdin),endstr))
break;
if(strlen(text) + strlen(buffer) + 1 > TEXTLEN)
{
printf("Maximum capacity for text exceeded. Terminating program.");
return 1;
}
strcat(text,buffer);
}
for(i = 0; i < strlen(text); i++)
{
if(text[i] == quote || isalnum(text[i]))
continue;
text[i] = space;
}
int index = 0;
while(true)
{
while(text[index] == space)
++index;
if(text[index] == '\0')
break;
wordlen = 0;
while(text[index] == quote || isalpha(text[index]))
{
if(wordlen == WORDLEN)
{
printf("Maximun word length exceeded.Terminating program.");
return 1;
}
word[wordlen++] = tolower(text[index++]);
}
word[wordlen] = '\0';
bool isnew = true;
for(i = 0; i < wordcount ; i++)
if(strcmp(word,words[i]) == 0)
{
++nword[i];
isnew = false;
break;
}
if(isnew)
{
if(wordcount >= MAXWORDS)
{
printf("\n Maximum word count exceeded.Terminating program.");
return 1;
}
strcpy(words[wordcount],word);
nword[wordcount++] = 1;
}
}
for(i = 0;i < wordcount; i++)
{
if( !(i%3) )
printf("\n");
printf("%-15s%5d",words[i],nword[i]);
}
return 0;
}
这篇关于linux下的c语言入门 - day6的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!