本题要求实现一个删除字符串中的指定字符的简单函数。
void delchar( char *str, char c );
其中char *str
是传入的字符串,c
是待删除的字符。函数delchar
的功能是将字符串str
中出现的所有c
字符删除。
#include
#define MAXN 20
void delchar( char *str, char c );
void ReadString( char s[] ); /* 由裁判实现,略去不表 */
int main()
{
char str[MAXN], c;
scanf("%c\n", &c);
ReadString(str);
delchar(str, c);
printf("%s\n", str);
return 0;
}
/* 你的代码将被嵌在这里 */
a
happy new year
hppy new yer
#include
void delchar( char *str, char c )
{
int i,j;
int len=strlen(str);
for(i=0;i
本题要求编写函数,将输入字符串t中从第m个字符开始的全部字符复制到字符串s中。
void strmcpy( char *t, int m, char *s );
函数strmcpy
将输入字符串char *t
中从第m
个字符开始的全部字符复制到字符串char *s
中。若m
超过输入字符串的长度,则结果字符串应为空串。
#include
#define MAXN 20
void strmcpy( char *t, int m, char *s );
void ReadString( char s[] ); /* 由裁判实现,略去不表 */
int main()
{
char t[MAXN], s[MAXN];
int m;
scanf("%d\n", &m);
ReadString(t);
strmcpy( t, m, s );
printf("%s\n", s);
return 0;
}
/* 你的代码将被嵌在这里 */
7
happy new year
new year
#include
void strmcpy( char *t, int m, char *s )
{
int len=strlen(t),i;
if(m>len)
*s=NULL;
else
{
for(i=m-1;i
void strmcpy(char* t, int m, char* s)
{
int i = m - 1, j = 0;
while (t[i] != '\0')
{
s[j++] = t[i];
i++;
}
s[j] = '\0';
return s;
}
本题要求实现一个函数,将两个字符串连接起来。
char *str_cat( char *s, char *t );
函数str_cat
应将字符串t
复制到字符串s
的末端,并且返回字符串s
的首地址。
#include
#include
#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 )
{
int len1=strlen(s);
int len2=strlen(t);
int i,j=0;
for(i=len1;i
本题要求实现一个将长整数转化成16进制字符串的简单函数。
void f( long int x, char *p );
其中x
是待转化的十进制长整数,p
指向某个字符数组的首元素。函数f
的功能是把转换所得的16进制字符串写入p
所指向的数组。16进制的A~F为大写字母。
#include
#define MAXN 10
void f( long int x, char *p );
int main()
{
long int x;
char s[MAXN] = "";
scanf("%ld", &x);
f(x, s);
printf("%s\n", s);
return 0;
}
/* 你的代码将被嵌在这里 */
123456789
75BCD15
-125
-7D
void f( long int x, char *p )
{
int len=0;
long int i,item;
if(x<0)
{
x=-x;
*p='-';
len++;
}
if(x==0)
*p='0';
for(item=x;item>0;item/=16)
len++;
for(i=0;i<10;i++)
{
item=x%16;
x/=16;
if(item<10)
*(p+len-1-i)=item+'0';
else
*(p+len-1-i)=item-10+'A';
if(x==0)
break;
}
}