一、字符数组的输入与输出
(第65课 采访报道) 教学视频
大惊小怪报和小惊大怪报是两家全球性的报社,发表的文章全用英文。因风之巅小学的信息学社团开展得很出色,于是两家报社都派记者前来采访,大惊小怪报采访尼克,小惊大怪报采访格莱尔。他俩写好采访稿后,想用一个字符个数统计程序比一比谁的字符数多,于是向狐狸老师求助。
编程:输入一段英文,统计字符个数(包含空格)和'.'出现的次数,再输出这段英文(字符数量不超过 2000 个)。一段英文其类型为字符串,但我们也可以用一个字符数组来存放一个字符串中的字符。
为了测定字符数组中字符串的实际长度, C++规定了以字符'\0'代表一个"字符串结束",一个字符串常量,系统会自动在所有的字符后面加一个'\0'作为结束符,然后再把它存储在字符数组中。在程序中往往依靠检测'\0'的位置来判定字符串是否结束,而不是根据数组的长度来决定字符串长度。流程图如图所示:
C++
#include <iostream>
#include <cstdio> //调用gets()和puts()函数
using namespace std;
int main()
{
char str[2000];
int i,num,numa;
num=numa=0;
gets(str);
for(i=0;str[i]!='\0';i++)
{
num++;
if(str[i]=='.')
numa++;
}
puts(str);
cout<<"字符个数 :"<<num<<endl;
cout<<".的个数:"<<numa<<endl;
return 0;
}
运行结果:
Glair is an expert programmer.(回车)(格莱尔是个编程高手。)
Glair is an expert programmer.
字符个数:30
.的个数:1
使用cin语句输入字符中时,遇到空格就结束,也就是说只能输入一个单词,而不能输入整行或包含空格的字符中,而用字符数组输入函数gets()输入字符串时可以包含空格。用cout语句可以输出包含空格的字符串,但字符数组输出函数puts()输出时会自动加上换行符,而cout语句不会。
小提示: 需要注意的是,使用gets(str)和puts(str)时,不能把str定义为字符串string型,只能定义为字符数组,否则编译时会出错。
C++允许一种特殊的字符常量,就是以一个"\"开头的字符序列,如'\0'代表字符串结束标志。这是一种"控制字符",是不能在屏幕上显示的,在程序中无法用一个一般形式的字符表示,只能采用特殊形式来表示。以''开头的特殊字符,称为转义符。部分转义符如表所示:
注:
gets [gets]get string的缩写 字符数组输入(字符串输入)
puts [puts]put string的缩写 字符数组输出(字符串输出)
练习
(1)已知变量strl、str2定义为string型,经过下列( )赋值后表达式(strl<str2)的为0。(字符串比较规则:从第一个字符开始,依次向后比较,直到出现第一个不同的字符为止,以第一个不同字符ASCII的大小确定其字符串的大小。)
A.str1="CD"; B.str1="HELLO"; C.str1="nike"; D.str1="8";
str2="CDDC"; str2="Hello"; str2="teacher"; str2="10+2";
(2)阅读程序写结果。
c++
#include <iostream>
using namespace std;
int main()
{
char str[20];
cin>>str;
cout<<str;
return 0;
}
输入:How are you
输出:____________
(3)完善程序。
从键盘上输人一段英文句子,统计并输出句子中各个小写字母出现的次数(设输入的字符小于1000个)
c++
#include <iostream>
#include <cstdio> //调用gets()和puts()函数
using namespace std;
int main()
{
char ch1[1000], ch2;
int num[26],i,k;
for(i=0;i<26;i++)
num[i]=0;
gets(chl);
i=0;
while(__________)
{
if(chl[i]>='a'&&ch1[i]<='z'>)
{
k=chl[i]-'a';
__________;
}
i++;
}
for(i=0;i<26;i++)
{
ch2='a'+i.
cout<<ch2<<':'<<num[i]<<" ";
if(i%5==4)cout <<endl;
}
retum 0;
}
二、字符串的输入与输出
(第66课 恺撒加密术)教学视频
加密术最早应用于古代战争。古罗马时期,恺撒大帝曾经使用密码来传息,它是一种替代密码,对于信件中的每个字母。会用它后面第i个字母代。
试编一程序,将输入的一段英文字符加密后输出,只加密字母,加密的规则是用原来字母后面的第1个字母代原来的字母,即用'b'代替'a',用'c'代替'b',······,用'a'代替'z',如图所示。
当把字符直接定义为string型时,可以用getlinet()函数来读取字符串,如"getline(cin,strl)",其中cin指的是输入流,strl是从输入流中读入的字符串存放的变量。加密时只要依次读取字符中每个字符进行加密即可,流程图如下两图所示。
c++
#include <iostream>
#include <string>
using namespace std;
int main()
{
char s;
string str1,str2;
getline(cin,str1);
int i;
str2=""; //空串也是字符串
for(i=0;i<str1.size();i++) //str1.szie()返回str1中字符个数
{
s=str1[i];
if((s>='a'&&s<='z')||(s>='A'&&s<='Z'))
{
s++;
if((s>'Z'&&s<'a')||s>'z')
s-=26;
}
str2+=s;
}
cout<<str2;
return 0;
}
运行结果:
Nike is excellent!(尼克是个非优秀的孩子!)
Ojlf jt fydfmmfoul!
恺撒加密术看起来非常巧妙,但随着计算机的诞生现已基本失效,因为它根本抵挡不住计算的枚举分析。当前计算机中使用比较广泛的加密算法有:RSA算法(公钥加密算法)、DES算法(又称"美国数据加密标准",是一种对称加密算法)、IDEA算法(国际数据加密算法)。
英汉小词典
getline['getlain]从输人流中读人一行(字符串)
练习
(1)重要的文件箱一般都有六个数字的密码锁,每一格都可以选择0~9这10个数字,这样排出的六位数密码共有( )个。
A.1万 B.10万 C100万 D1000万
(2)阅读程序写运行结果。
c++
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str;
int i, ans;
i=0;
ans=1;
geline(cin,str);
while(i<str.size())
{
if(i>0)
if(str[i]==32&&str[i-1]!=32)
ans++;
i++;
}
cout<<ans<<endl;
return 0;
}
输入:How are you
输出:________________
(3)完善程序。
解密,输入一段加密后的英文字符解密成原码并输出(加密时用恺撒加密术,只加密字母,用它后面的第3个字母代替)。
如输人:gdgd2
则输出:dada2
c++
#include <iostream>
#include <string>
using namespace std;
int main()
{
char s;
string strl,str2;
int i;
------------------------------;
for(i=0;i<str1.size();i++)
{
s=str1[i];
if((s>='a' && s<='z')||(s>='A'&&s<='Z'))
{
s-=3;
if((s>'Z'&&s<='a')||s<'A')
s+=26;
str2+=s;
}
else
__________;
}
cout<<str2;
return 0;
}
三、筛选法
(第67课 快速求素数)教学视频
筛选法是古希著名数学家埃托色尼提里的一种求素数的方法。如求100以内的素数,他采取的方法是,先在一张纸上按顺序写出1~100的全部整数,然后按下列步操作:先把1删除(1既不是素数也不是合数);读取当前剩下数中最小的数2,然后把2后面的是2的倍数的数删去;读取当前剩下数中最小的数3,然后把3后面的是3的倍数的数删去;该取当前剩下数中最小的数5、然后把5后面的是5的倍数的数删去······。以此类推,直到所有的数均删除或读攻。剩下未删除的数就是素数。
试编一程序,用选选法输出100以内所有的素数,并统计个数。
流程图如下图:
c++
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int a[101];
int i,j,num;
for(i=2;i<=100;i++)
a[i]=true;
a[0]=a[1]=false;
i=1;
do
{
i++;
if(a[i])
{
for(j=2;j<=100/i;j++)
a[i*j]=false;
}
}while(i<100);
num=0;
for(i=1;i<=100;i++)
{
if(a[i])
{
cout<<setw(6)<<i;
num++;
if(num%10==0) cout<<endl;
}
}
cout<<endl;
cout<<"100以内素数个数:"<<num<<endl;
return 0;
}
练习
(1)计算机病毒的描述中正确的是()。
A.如果某人有感冒病毒,那他使用的计算机就有可能感染病毒,并最终发展成为计算机病毒。
B.若计算机在生产厂家组装时周围环境不好(有灰尘等),计算机就会有计算机病毒。
C.计算机病毒实质上是一段计算机程序。
D.计算机病毒只能通过计算机网络传播。
(2)阅读程序写运行结果。
c++
#include <iostream>
using namespace std;
int main()
{
char s1[]="study", s2[]="student";
int i、ans=0;
for(i=0;sl[i]!='\0'&&s2[i]!='\';i++)
if(sl[i]==s2[i])
ans++;
cout<< ans<< endl;
return 0;
}
i,ans输出:_________________________
(3)完善程序。
尼克有一堆小于50根的胡卜,格莱尔帮他两根两根地数多1根,3根3根地数多2根,7根7根数多5根。请用筛选法算一算。尼克可有几根胡萝卜。
c++
#include <iostream>
#include <cstring> //使用memset()函数设置数组元素的初始值
using namespace std;
int main()
{
bool a[50];
int i,b[3]={1, 2, 5};
memsetf(a,true, sizeof(a)); //数组a所有元素初始化为true
for(i=1; i<30;i++)
{
if(i%2!=b[0]) a[i]=false;
if(i%3!=b[1]) __________;
if(i%7!=b[2]) a[i]=false;
}
for(i=1; i<50;i++)
if(______) cout<<i<<endl;
return 0;
}