第二次作业

6-7 删除字符串中数字字符
(1)主要描述题目算法
1.将数字全部后移
2.将字符串中的第一个数字用'\0'代替
3.输出这个数组
(2)实现代码

#include "stdio.h"
void delnum(char *s);
int main ()
{ char item[80];
gets(item);
 delnum(item);
 printf("%s\n",item);
 return 0;
}
delnum(char *s)
{
    char a[80]={0};
    int i=0,j=0;
    while(*(s+i))
    {
        if(!(*(s+i)<='9'&&*(s+i)>='0'))
            a[j++]=*(s+i);
        i++;
    }
    i=0;
    while(a[i++])
        *(s+i)=a[i];
    *(s+i-1)='\0';
}

3.本题调试过程碰到问题及解决办法

git地址:https://git.coding.net/gbztdn/diercizuoye.git

1360873-20180408103734310-1272380887.png

6-8 统计子串在母串出现的次数

(1)主要描述题目算法

1.用strncmp函数比较数组中对应个数的字符串

2.用n记录字符串出现的个数

3.输出n的值

(2)实验代码

#include<stdio.h>
int fun(char *str,char *substr);
int main()
{ char str[81]="asdasasdfgasdaszx67asdmklo",substr[4]="asd";
 int n;
 n=fun(str,substr);
 printf("n=%d\n",n);
 return 0;
}
fun(char *str,char *substr)
{
    int n=0;
    while(*(str))
    {
        if(strncmp(str,substr,3)==0)
        {
           n++;
        }
        str+=1;

    }
    return n;
}

3.注意事项
(1)调用strncmp要用头文件string.h

git地址:https://git.coding.net/gbztdn/diercizuoye.git

1360873-20180408104348596-1699636032.png

6-9 字符串中除首尾字符外的其余字符按降序排列
(1)主要描述题目算法

1.遍历数组

2.将字符排序

(2)实验代码

#include <stdio.h>
int fun(char *s,int num);
int main()
{
 char s[10];
 gets(s);
 fun(s,7);
 printf("%s",s);
 return 0;
 }
fun(char *s,int num)
{
    int i,j;
    char a = *(s+num-1);
    *(s+num-1)='\0';
    for(i=0; i<num; i++)
    {
        for(j=1; j<num-i; j++)
        {
            if(*(s+j)<*(s+j+1))
            {
                char temp;
                temp=*(s+j+1);
                *(s+j+1)=*(s+j);
                *(s+j)=temp;
            }

        }
    }
    *(s+num-1)=a;
}

3.本题调试过程碰到问题及解决办法
(1).冒泡排序需要两个for循环

git地址:https://git.coding.net/gbztdn/diercizuoye.git

1360873-20180408105040186-1358477060.png

7-1 输出学生成绩
(1).主要描述题目算法
1.遍历数组
2.分别用函数找出最大最小值
3.将数组中的第一位传给max和min
4.将数组中的没一个数和max,min比较
(2).实验代码

#include <stdio.h>
float miny(float x,float y);
float maxy(float x,float y);
int main()
{
    int N,grade,k,i=1;
    float average,max,min,sum=0.0;


    scanf("%d",&N);
    for(k=0; k<N; k++)
    {
        scanf("%d",&grade);
        sum+=grade;
        if (i==1)//注意判断是否等于是“==”
        {
            max=grade;
            min=grade;
            i--;//控制只运行一次
        }
        max=maxy(max,grade);
        min=miny(min,grade);
    }
    average=sum/N;
    printf("average = %.2f\nmax = %.2f\nmin = %.2f",average,max,min);
    return 0;
}
float maxy(float x,float y)
{
    float z;
    if(x>y)
        z=x;
    else
        z=y;
    return(z);
}
float miny(float x,float y)
{
    float z;
    if(x<y)
        z=x;
    else
        z=y;
    return(z);
}

3.本题调试过程碰到问题及解决办法
(1)只将max和min赋值一次

        if (i==1)//注意判断是否等于是“==”
        {
            max=grade;
            min=grade;
            i--;//控制只运行一次
        }

git地址:https://git.coding.net/gbztdn/diercizuoye.git

1360873-20180408110150401-1642405967.png

这两周来所有PTA作业中题目所使用的知识点:

1.字符串与指针的关系

2.函数指针调用函数

3.指针作函数参数

4.循环语句等基础知识

请用表格和折线图呈现你本周的代码行数和时间、博客字数和时间

1360873-20180408115130636-309982583.png

转载于:https://www.cnblogs.com/zqs1314520/p/8743712.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.编写一个JSP程序,计算1!+2!+3!+4!+5!,并显示出结果。要求先声明计算阶乘的方法,再调用该方法,最后在页面上输出结果。2.2、在JSP页面中静态包含文件。要求程序包含两个文件,主文件静态包含一个能够计算1到1000内的完数的页面。(如果一个正整数刚好等于它的真因子之和,这样的正整数为完数, 例如,6=1+2+3,因此6就是一个完数。)3.动态包含页面并传递数据。要求程序包含两个文件,主文件(actioninclude)加载次文件(redirection),并将随机产生的50~100之间的数据传递给它,并且在页面上显示两个信息:该数据和这个数据的平方根。进阶要求,把动态包含改为动态重定向,比较两者之间的区别。4.本题包括4个JSP程序,one.jsp、two.jsp、three.jsp、error.jsp。 one.jsp具体要求如下:要求one.jsp页面有一个表单,用户使用该表单可以输入一个1至100之间的整数,并提交给下一个页面;如果输入的整数在50至100之间(不包括50)就转向three.jsp,如果在1至50之间就转向two.jsp;如果输入不符合要求就转向error.jsp。要求forward标记在实现页面转向时,使用param子标记将整数传递到转向的two.jsp或three.jsp页面,将有关输入错误传递到转向的error.jsp页面 two.jsp、three.jsp和error.jsp的具体要求如下: 要求two.jsp和three.jsp能输出one.jsp传递过来的值,并显示一幅图像,该图像的宽和高刚好是one.jsp页面传递过来的值。error页面能显示有关抛出的错误信息。(程序中使用的图片,可自行准备)。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值