1、改错:
(a)、void test1()
{
char string[10];//改成11
char *str1 = "0123456789";//strlen(str1[]) = 11
strcpy(string, str1);
}
(b)、void test2()
{
char string[10], str1[10];
for (i=0; i<10; i++)
{
str1[i] = 'A';//没有'\0'结尾标志
}
strcpy(string, str1);
}
(c)、void test3(char *str)
{
char string[10];
if (strlen(str1)<=10)
{
strcpy(string, str1);//可能我觉得没问题吧
}
}
2、找赛手:2个羽毛球队比赛,各出3人,每个人只比一次。甲队为A,B,C三人,乙队为X,Y,Z三人。有人打听比赛名单,A说他不和X比,C说不和X,Z比。编程找出三队赛手的名单.
C和Y比,A和Z比,B和X比。
#include<stdio.h>
#include<stdio.h>
int main()
{
int i,j;
for(i='A';i<='C';i++)
{
for(j='X';j<='Z';j++)
{
if(!(i=='A'&&j=='X'||i=='C'&&(j=='X'||j=='Z')))
printf("%c----%c\n",i,j);
}
}
return 0;
}
3、用C语言实现字符串中子字符串的替换, 成功返回0,失败返回-1.例如:“ABCDEFG”这个字符串,把其中”BCD”替换成“9527”这个子串,结果变成:“A9527EFG”
函数原型:
int str_replace(char str, char replaced_str, char *new_str)
int str_replace(char *str, char *replaced_str, char *new_str)
{
int i = 0, j = 0, k = 0, l = 0, m = 0;
while(str[i])
{
if(str[i] == replaced_str[j])
{
k = i;
while((str[++i]==replaced_str[++j]) && str[i]);
}
else
i++;
if(0 == replaced_str[j])
break;
else
j = 0;
}
if(replaced_str[j])
return -1;
l = strlen(str);
for(i = 0;(new_str[i] && i) < j;i++)
str[k++] = new_str[i];
if(0 == new_str[i])
while(str[k++] = str[k + j - i]);
else
{
for(k = 0, j = l + 1; k < m; k++, j--)
str[j] = str[j-1];
str[j] = new_str[i];
}
return 0;
}
int main(void)
{
char str[100] = "abcdefgh";
printf("%d, %s\n", str_replace(str, "cd", "2323"), str);
return 0;
}
//1、:(1)分析程序,为什么?
/* //分析:堆内存申请时,申请内存字节数0,会返回一个有效//的地址值,也就是会得到一个可被使用的内存。编译器会默认分
//配一块最小内存。至于最小默认值是多大,取决于编译器
char *ptr;
if ((ptr = (char *)malloc(0)) == NULL)
puts("Got a null pointer");
else
puts("Got a valid pointer");
//输出Got a valid pointer
//malloc(0)是可以正常返回一个非NULL值的。
(2)分析程序,为什么?
//分析:GetStr函数返回的是,局部变量tmp,可是这个变量指向//的内存会在函数调用结束时释放,可能你会找到字符串”123”,//但是你已经错了。
char * GetStr()
{
char *tmp;
tmp = "123"
return tmp;
}
void main()
{
printf("%s.\n", GetStr());
}
*/
//输出123
//返回指针 指向 常量123,程序正常结束后才释放
//2、输入一个正整数,输出原数并逆序打印出各位数字。
//例如:原数:123456 逆序:654321
//逆序函数原型:int invers_int(int x)(需要用到递归实现)
/*
#include <stdio.h>
//逆序函数
int invers_int(int x)
{
//递归函数的回归条件
if (x >= 0 && x <= 9)
{
printf("%d\n", x);
}
else
{
//打印出原数的个位
printf("%d", x%10);
//原数去掉了个位的新数
invers_int(x/10);
}
}
int main(void)
{
//从终端输入一个正整数,
int x = 0;
printf("输入一个数:\n");
scanf("%d", &x);
//输出原数
printf("%d.\n", x);
//逆着输出原数
invers_int(x);
return 0;
}
*/
//3、按以下规律翻译密码:
// 将每一个字母变成它后面的字母,例如,将A变成B,B变成C,…,Z变成A,
// 非字母字符不变,“!”作为电文结束标志。
#include <stdio.h>
int main()
{
char ch;
printf("输入字符串:\n");
//输入字符串
while ((ch=getchar())!='!')
{
//判断是不是字母
if ((ch>='a' && ch<='z')||(ch>='A' &&ch<='Z'))
{
if (ch == 'z')
{
ch='a';
}
else if (ch=='Z')
{
ch='A';
}
else
{
ch=ch+1;
}
printf("%c",ch);
}
}
printf("\n");
return 0;
}
1、编写程序:读入一个在字母C和X之间的字符,打印出该字母在中间的相邻五个字母。
如:输入F,则输出DEFGH.
函数原型:void func(char ch)
#include<stdio.h>
void xlwzm(char zm)
{
printf("%c %c %c %c %c\n",zm-2,zm-1,zm,zm+1,zm+2)
}
int main()
{
char zm;
printf("请输入一个字母,按回车结束:");
getchar(zm);
xlwzm;
return 0;
}
2、一个球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第十次反弹多高。
#include<stdio.h>
int main()
{
float hight=100,sum=0;
int i;
for(i=1;i<=10;i++)
{
sum = sum + hight + hight/2;
hight = hight/2;
}
printf("第%d次落地时,共经过%f米\n",i,sum);
printf("第%d次反弹%f米\n",i,hight);
return 0;
}
3、编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的下一秒。如输入2004年12月31日23时59分59秒,则输出2005年1月1日0时0分0秒。
函数原型:PS:故意这么写的,别给乱换
void show_time(int *year, int *month, int *date, int *hour, int *minute, int *second)
五个if语句嵌套的笨办法,判断秒是否小于59,是则秒+1,输出,否则秒置0再判断分是否小于59,依次类推。没想到好办法。希望老师周日快放学的时候给我们“砸苹果”