题目:计算字符串中子串出现的次数
#include<cstdio>
#include<cstring>
char s1[20],s2[20],*p1,*p2;
int cnt;
// 全局变量默认初始值为0
// 这里其实可以通过kmp算法或者ac自动机算法实现
// 但是由于好久不写了,就写最简单的算法吧
// 如果有兴趣的话可以学一下hash,可以做很多字符串的事情
int main()
{
//这里默认s1为母串,s2为子串
scanf("%s%s",s1,s2);
p1=s1, p2=s2;
while(*p1 !='\0')
{
if(*p1==*p2)
{
while(*p1==*p2 && *p2 !='\0')
p1++,p2++;
}
else
p1++;
if(*p2=='\0')
cnt++;
p2=s2;//什么时候p2重置呢?
}
printf("%d",cnt);
}
题目:从键盘输入一些字符,逐个把它们送到磁盘上去,直到输入一个#为止。
#include<cstdio>
#include<cstdlib>
char ch,filename[10];
int main()
{
FILE *fp;//文件指针
scanf("%s",filename);
// 这里默认此文件与程序在同一文件夹
fp=fopen(filename,"w");
// 实际上如果找不到的话,这里会自动创建一个
// 要注意这个是相对路径,如果要处理绝对路径怎么办?
if(fp==NULL)
{
printf("don't find file named\"%s\"",filename);
exit(0);//强制在此处终止程序
}
ch=getchar();//起到什么作用?
while((ch=getchar()) !='#')
{
// 不运行的话,下面的代码哪个是写入文件?
fputc(ch,fp);//写入文件,会换行吗?
putchar(ch);// 运行时候可以把这里注释掉
}
fclose(fp);//记得关掉
}
题目:从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件“test”中保存。输入的字符串以!结束。
#include<cstdio>
#include<cstdlib>
char str[100],filename[10];
int i;
int main()
{
FILE *fp;
fp=fopen("test","w");
if(fp==NULL)
{
printf("don't find file named\"%s\"",filename);
exit(0);//强制在此处终止程序
}
gets(str);//读取一行字符串,要注意!结尾
// 大写字母与小写字母的ascii码差32
while(str[i]!='!')
{
if(str[i] >='a' && str[i] <='z')
str[i]=str[i]- 32;
i++;
}
fprintf(fp,"%s",str);
//这个是直接向文件中输出的
// 是追加还是覆盖呢? 这个由什么决定?
// 由fopen的第二个参数决定https://www.runoob.com/cprogramming/c-function-fopen.html
fclose(fp);
}
题目:有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件C中。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define R register
// 最简单的想法就是两个同时读入到一个字符数组,再利用排序算法进行排序
// 两个代码都是这样的
// 这里先用不同的方法进行实现
// 可以先了解一下fgets函数
/*
fgets(str,n,fp);
str:指向一个字符数组的指针
n:要读取的最大字符数(包括最后的空字符)
fp: 指向 FILE 对象的指针
*/
void sswap(R char &x, R char &y)
{
char t=x;
x=y;
y=t;
}
char a[100],b[100],c[200];
int main()
{
FILE *fp;
fp=fopen("A","r");
// 这个不会自动生成的
if(fp==NULL)
{
puts("don't find file \"A\"");
exit(0);//强制在此处终止程序
}
fgets(a,100,fp);
fclose(fp);
/*隔开*/
fp=fopen("B","r");
fgets(b,100,fp);
if(fp==NULL)
{
puts("don't find file \"B\"");
exit(0);//强制在此处终止程序
}
fclose(fp);
/*隔开*/
strcat(a,b);
int len=strlen(a);
for(R int i=1;i < len;i++)
for(R int j=0;j < len-1;j++)
if(a[j] > a[j+1])
sswap(a[j],a[j+1]);
fp=fopen("C","w");
fprintf(fp,"%s",a);
fclose(fp);
}
下面是书中使用的代码:
#include<cstdio>
#include<cstdlib>
// 这里改了一下头文件,调整了一下排版
// 基本原理相同
int main()
{
FILE *fp;
int i,j,n;
char c[160],t,ch;
if((fp=fopen("A","r"))==NULL)
{
printf("file A cannot be opened\n");
exit(0);
}
printf("\n A contents are :\n");
for(i=0;(ch=fgetc(fp)) !=EOF;i++)
{
c[i]=ch;
putchar(c[i]);
}
fclose(fp);
//分隔
if((fp=fopen("B","r"))==NULL)
{
printf("file B cannot be opened\n");
exit(0);
}
printf("\n B contents are :\n");
for(i=0;(ch=fgetc(fp)) !=EOF;i++)
{
c[i]=ch;
putchar(c[i]);
}
fclose(fp);
// 分隔
n=i;
for(i=0;i < n;i++)
for(j=i + 1;j < n;j++)
if(c[i] > c[j])
{
t=c[i];
c[i]=c[j];
c[j]=t;
}
printf("\n C file is:\n");
fp=fopen("C","w");
for(i=0;i < n;i++)
{
putc(c[i],fp);
putchar(c[i]);
}
fclose(fp);
}
题目:有五个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括学生号,姓名,三门课成绩),计算出平均成绩,况原有的数据和计算出的平均分数存放在磁盘文件"stud"中。
0
本例参考了网上的例子,唯一不一样的是,我这里的操作是一步一步讲解,网上仅是源码。
一、我们先创建一张空白的网页,网页要自适应手机。
图1
二、我们再创建网页的头部。
图2
图3
三、做出来的网页头部太丑了,我们要去掉盒子与浏览器的间隙,还有给头部加内部距离。
图4
图5
四、给网页头部添加一些内容。
图6
图7
五、接下来开始做导航条了。
图8
图9
六、发现没,导航条居然看不见,没有东西在里面自然是看不见的,我们加三个链接吧。
图10
图11
七、这回是看见了,不过样式太丑,我们改改样式。
图12
图13
八、加上内部距离,就好看了许多,即然是链接,我们加点动态吧,当鼠标在链接上面时,链接块变色。
图14
图15
九、开始做网页内容,网页内容我分为三块,左右两边是侧栏,中间是主要内容。
图16
图17
十、我想让它横着排,它却是竖着排,改改各个块的样式。
图18
图19
十一、给主体的各个块加点内容。
图20
图21
十二、内容是有了,但你会发现各块之间没有间隙,贴得太近了,我们改一下样式,加个内部距离。
图22
图23
十三、距离是有了,但有一个侧栏跑到了另一行,怎么回事?原来padding是会改变盒子的整体宽度,我们原本是100%,现在多了padding的宽度,自然就换行了,解决一下吧。
图24
图25
十四、这回终于在一行了,接下来可以做网页底部了。
图26
图27
十五、改改样式,让底部好看一点。
图28
图29
十六,这个时候,网页的整体版面就完成了,再补充一个小内容,让网页浏览器在小于600像素宽的时候,主体内容的三个块由横变竖。
图30
图31
题目:计算字符串中子串出现的次数
#include<cstdio>
#include<cstring>
char s1[20],s2[20],*p1,*p2;
int cnt;
// 全局变量默认初始值为0
// 这里其实可以通过kmp算法或者ac自动机算法实现
// 但是由于好久不写了,就写最简单的算法吧
// 如果有兴趣的话可以学一下hash,可以做很多字符串的事情
int main()
{
//这里默认s1为母串,s2为子串
scanf("%s%s",s1,s2);
p1=s1, p2=s2;
while(*p1 !='\0')
{
if(*p1==*p2)
{
while(*p1==*p2 && *p2 !='\0')
p1++,p2++;
}
else
p1++;
if(*p2=='\0')
cnt++;
p2=s2;//什么时候p2重置呢?
}
printf("%d",cnt);
}
题目:从键盘输入一些字符,逐个把它们送到磁盘上去,直到输入一个#为止。
#include<cstdio>
#include<cstdlib>
char ch,filename[10];
int main()
{
FILE *fp;//文件指针
scanf("%s",filename);
// 这里默认此文件与程序在同一文件夹
fp=fopen(filename,"w");
// 实际上如果找不到的话,这里会自动创建一个
// 要注意这个是相对路径,如果要处理绝对路径怎么办?
if(fp==NULL)
{
printf("don't find file named\"%s\"",filename);
exit(0);//强制在此处终止程序
}
ch=getchar();//起到什么作用?
while((ch=getchar()) !='#')
{
// 不运行的话,下面的代码哪个是写入文件?
fputc(ch,fp);//写入文件,会换行吗?
putchar(ch);// 运行时候可以把这里注释掉
}
fclose(fp);//记得关掉
}
题目:从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件“test”中保存。输入的字符串以!结束。
#include<cstdio>
#include<cstdlib>
char str[100],filename[10];
int i;
int main()
{
FILE *fp;
fp=fopen("test","w");
if(fp==NULL)
{
printf("don't find file named\"%s\"",filename);
exit(0);//强制在此处终止程序
}
gets(str);//读取一行字符串,要注意!结尾
// 大写字母与小写字母的ascii码差32
while(str[i]!='!')
{
if(str[i] >='a' && str[i] <='z')
str[i]=str[i]- 32;
i++;
}
fprintf(fp,"%s",str);
//这个是直接向文件中输出的
// 是追加还是覆盖呢? 这个由什么决定?
// 由fopen的第二个参数决定https://www.runoob.com/cprogramming/c-function-fopen.html
fclose(fp);
}
题目:有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件C中。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define R register
// 最简单的想法就是两个同时读入到一个字符数组,再利用排序算法进行排序
// 两个代码都是这样的
// 这里先用不同的方法进行实现
// 可以先了解一下fgets函数
/*
fgets(str,n,fp);
str:指向一个字符数组的指针
n:要读取的最大字符数(包括最后的空字符)
fp: 指向 FILE 对象的指针
*/
void sswap(R char &x, R char &y)
{
char t=x;
x=y;
y=t;
}
char a[100],b[100],c[200];
int main()
{
FILE *fp;
fp=fopen("A","r");
// 这个不会自动生成的
if(fp==NULL)
{
puts("don't find file \"A\"");
exit(0);//强制在此处终止程序
}
fgets(a,100,fp);
fclose(fp);
/*隔开*/
fp=fopen("B","r");
fgets(b,100,fp);
if(fp==NULL)
{
puts("don't find file \"B\"");
exit(0);//强制在此处终止程序
}
fclose(fp);
/*隔开*/
strcat(a,b);
int len=strlen(a);
for(R int i=1;i < len;i++)
for(R int j=0;j < len-1;j++)
if(a[j] > a[j+1])
sswap(a[j],a[j+1]);
fp=fopen("C","w");
fprintf(fp,"%s",a);
fclose(fp);
}
下面是书中使用的代码:
#include<cstdio>
#include<cstdlib>
// 这里改了一下头文件,调整了一下排版
// 基本原理相同
int main()
{
FILE *fp;
int i,j,n;
char c[160],t,ch;
if((fp=fopen("A","r"))==NULL)
{
printf("file A cannot be opened\n");
exit(0);
}
printf("\n A contents are :\n");
for(i=0;(ch=fgetc(fp)) !=EOF;i++)
{
c[i]=ch;
putchar(c[i]);
}
fclose(fp);
//分隔
if((fp=fopen("B","r"))==NULL)
{
printf("file B cannot be opened\n");
exit(0);
}
printf("\n B contents are :\n");
for(i=0;(ch=fgetc(fp)) !=EOF;i++)
{
c[i]=ch;
putchar(c[i]);
}
fclose(fp);
// 分隔
n=i;
for(i=0;i < n;i++)
for(j=i + 1;j < n;j++)
if(c[i] > c[j])
{
t=c[i];
c[i]=c[j];
c[j]=t;
}
printf("\n C file is:\n");
fp=fopen("C","w");
for(i=0;i < n;i++)
{
putc(c[i],fp);
putchar(c[i]);
}
fclose(fp);
}
题目:有五个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括学生号,姓名,三门课成绩),计算出平均成绩,况原有的数据和计算出的平均分数存放在磁盘文件"stud"中。
*请认真填写需求信息,我们会在24小时内与您取得联系。