c语言练习(4)

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,依次类推。没想到好办法。希望老师周日快放学的时候给我们“砸苹果”
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值