计算最长的字符串长度
本题要求实现一个函数,用于计算有n个元素的指针数组s中最长的字符串的长度。
int max_len( char *s[], int n );
其中n
个字符串存储在s[]
中,函数max_len
应返回其中最长字符串的长度。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXN 10
#define MAXS 20
int max_len( char *s[], int n );
int main()
{
int i, n;
char *string[MAXN] = {NULL};
scanf("%d", &n);
for(i = 0; i < n; i++) {
string[i] = (char *)malloc(sizeof(char)*MAXS);
scanf("%s", string[i]);
}
printf("%d\n", max_len(string, n));
return 0;
}
/* 你的代码将被嵌在这里 */
4
blue
yellow
red
green
6
int max_len(char *s[], int n)
{
int max = (int) strlen(s[0]);
for (int i = 1; i < n; i++)
{
max = (int) strlen(s[i]) > max ? (int) strlen(s[i]) : max;
}
return max;
}
字符串的连接
本题要求实现一个函数,将两个字符串连接起来。
char *str_cat( char *s, char *t );
函数str_cat
应将字符串t
复制到字符串s
的末端,并且返回字符串s
的首地址。
#include <stdio.h>
#include <string.h>
#define MAXS 10
char *str_cat( char *s, char *t );
int main()
{
char *p;
char str1[MAXS+MAXS] = {'\0'}, str2[MAXS] = {'\0'};
scanf("%s%s", str1, str2);
p = str_cat(str1, str2);
printf("%s\n%s\n", p, str1);
return 0;
}
/* 你的代码将被嵌在这里 */
abc
def
abcdef
abcdef
char *str_cat( char *s, char *t )
{
char *p=s;
s=s+strlen(s);
while(*t!='\0')
{
*s=*t;
s++;
t++;
}
return p;
}
指定位置输出字符串
本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
char *match( char *s, char ch1, char ch2 );
函数match
应打印s
中从ch1
到ch2
之间的所有字符,并且返回ch1
的地址。
#include <stdio.h>
#define MAXS 10
char *match( char *s, char ch1, char ch2 );
int main()
{
char str[MAXS], ch_start, ch_end, *p;
scanf("%s\n", str);
scanf("%c %c", &ch_start, &ch_end);
p = match(str, ch_start, ch_end);
printf("%s\n", p);
return 0;
}
/* 你的代码将被嵌在这里 */
program
r g
rog
rogram
program
z o
(空行)
(空行)
program
g z
gram
gram
char *match( char *s, char ch1, char ch2 )
{
int i, flag=0;
char *p=NULL;
for(i=0;*(s+i)!='\0';i++)
{
if(*(s+i)==ch1||flag==1)
{
if(flag==0)p=s+i;
printf("%c",*(s+i));
flag=1;
}
if(flag==1&&*(s+i)==ch2)break;
}
printf("\n");
if(p==NULL)
p=s+i;
return p;
}
标签:int,max,样例,PTA,C语言,char,str,字符串,指针
From: https://blog.51cto.com/heliotopekxy/8946398