Ⅰ C++编程,用标准库和输入输出流
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
#include <math.h>
void main()
{
int i,len,sum;
char str[50];
FILE *fp1,*fp2;
if((fp1=fopen("text.txt","rt"))==NULL)
{
printf("不能打开 text.txt 文件\n");
return;
}
if((fp2=fopen("new.txt","wt"))==NULL)
{
printf("不能打开new.txt文件\n");
return;
}
while(!feof(fp1))
{
fscanf(fp1,"%s",str);
len=strlen(str);
sum=0;
for(i=0; i<len; i++)
sum+= (str[i]-'0') * pow(2, len - i-1);
itoa(sum,str,16);
fprintf(fp2,"%s\n",str);
printf("%s\n",str);
}
fclose(fp1);
fclose(fp2);
}
Ⅱ C++编程,用标准库和输入输出流做
下午没事,于是拿这个程序练手了,写了个模板。
我这个程序有个要求:
每行最大字节数1024,如果不爽可以在define那里修改
main函数里面有路径。你设置成自己的。
#include <iostream>
#include <string>
#include <strstream>
#include <fstream>
#include <vector>
#define MAX_LINESIZE 1024
template <typename T>
class CMatrix
{
public:
CMatrix(std::string filename);
~CMatrix(){};
void transform(std::string filename);
private:
std::vector<std::vector<T>>m_matrix;
};
template<typename T>
CMatrix<T>::CMatrix(std::string filename)
{
std::ifstream ifs(filename.c_str());
if(!ifs)
{
std::cout<<"Waring: The file "<<filename<<" can not be opened."<<std::endl;
}
T element;
std::vector<T> line;
char fline[MAX_LINESIZE];
while(!ifs.eof())
{
line.clear();
ifs.getline(fline,MAX_LINESIZE);
std::string sline(fline);
std::strstream sstr;
sstr<<sline;
while(!sstr.eof()&&!sline.empty())
{
sstr>>element;
line.push_back(element);
}
if(!line.empty())//Consider if any line is empty, especially the last line
m_matrix.push_back(line);
}
ifs.close();
}
template <typename T>
void CMatrix<T>::transform(std::string filename)
{
std::vector<std::vector<T>> matrix=m_matrix;//The function does not change the stored matrix.
std::vector<std::vector<T>>::iterator iter1,iter2;
std::vector<T>::iterator it1,it2;
//vertical transform
std::vector<T> ltmp;
for(iter1=matrix.begin(),iter2=matrix.end()-1;iter1<iter2;iter1++,iter2--)
{
ltmp=*iter1;
*iter1=*iter2;
*iter2=ltmp;
}
T tmp;
for(iter1=matrix.begin();iter1!=matrix.end();iter1++)
{
for(it1=(*iter1).begin(),it2=(*iter1).end()-1;it1<it2;it1++,it2--)
{
tmp=*it1;
*it1=*it2;
*it2=tmp;
}
}
//I strongly suggest that you separate calculate and display. However, this program is just to realise your demand.
std::ofstream ofs(filename.c_str());
if(!ofs)
{
std::cout<<"Waring: The file "<<filename<<" can not be opened."<<std::endl;
}
for(iter1=matrix.begin();iter1!=matrix.end();iter1++)
{
for(it1=(*iter1).begin();it1!=(*iter1).end();it1++)
{
ofs<<*it1;
std::cout<<*it1;
if(*it1!=(*iter1).back())//check if current element is the last element of current line
{
ofs<<" ";
std::cout<<" ";
}
}
if(*iter1!=matrix.back())
{
ofs<<std::endl;
std::cout<<std::endl;
}
}
}
void main()
{
CMatrix<int> matrix("C:\\Documents and Settings\\zhuantou88\\Desktop\\matrix.txt");
matrix.transform("C:\\Documents and Settings\\zhuantou88\\Desktop\\new.txt");
std::cout<<std::endl;
system("pause");//call system pause
}
Ⅲ 学游戏编程用学C++标准库吗
标准库适用于各种应用,做应用领域都需要。
Ⅳ 编程中库是什么意思
例如:#incluede "stdio.h" 这个头文件,就是库的意思
库,也就是里面定义了很多的函数、字段等等
补充:编程就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到相应结果的过程。
为了使计算机能够理解人的意图,人类就必须要将需解决的问题的思路、方法、和手段通过计算机能够理解的形式告诉计算机,使得计算机能够根据人的指令一步一步去工作,完成某种特定的任务。这种人和计算机之间交流的过程就是编程。
编程:设计具备逻辑流动作用的一种"可控体系"【注:编程不一定是针对计算机程序而言的,针对具备逻辑计算力的体系,都可以算编程】
例子:①比如编写一段代码程序②编写一个控制设备体系
Ⅳ 如何利用Python标准库编程
第一步、根据自己的业务需求声明一个继承自Python标准库的模块
# 接收流量类,继承自asyncore.dispatcher,class Receiver(asyncore.dispatcher):
def __init__(self,conn):
asyncore.dispatcher.__init__(self,conn)
self.from_remote_buffer='' # 接收数据的缓冲区
self.to_remote_buffer='' # 发送数据的缓存区
self.sender=None1234567
第二步、根据文档,重写模块中的方法,这些方法有些像生命周期中的事件,你可以通过在这些事件中自定义代码,使得在特定时间点执行特定的代码。
# 接收流量类,继承自asyncore.dispatcher,class Receiver(asyncore.dispatcher):
def __init__(self,conn):
asyncore.dispatcher.__init__(self,conn)
self.from_remote_buffer='' # 接收数据的缓冲区
self.to_remote_buffer='' # 发送数据的缓存区
self.sender=None
# 当活动opener的套接字真正创建连接时被调用。也许发送一个“欢迎”字符串数据,或者比如,初始化一个远程端点的协商协议。
def handle_connect(self):
pass
# 当异步循环检测到一个在信道套接字上的read()调用时会成功被调用。
def handle_read(self):
read = self.recv(BUFSIZE)
self.from_remote_buffer += read # 每次在异步循环中被调用来决定是否一个信道的套接字应该被加到写事件可以发生的列表中。 默认方法简单地返回 True,显然,所有的信道会关注于写事件。
def writable(self):
return (len(self.to_remote_buffer) > 0) # 当异步循环检测到一个可写入的的套接字可以被写入时被调用。常用这个方法为了性能优化实现必要的缓存。
def handle_write(self):
sent = self.send(self.to_remote_buffer)
self.to_remote_buffer = self.to_remote_buffer[sent:] # 当套接字被关闭的时候调用
def handle_close(self):
self.close() if self.sender:
self.sender.close()
Ⅵ 求C++编程,要用标准库和输入输出流做
貌似刚才回答过一个你的问题?
#include <iostream>
using namespace std;
int main()
{
int vect[6][6];
for(int i=0; i<6; ++i) {
for(int j=0; j<6; ++j) {
cin >>vect[i][j];
}
}
int sum[6];
for(int j=0; j<6; ++j) {
sum[j] = 0;
for(int i=0; i<6; ++i) {
sum[j] += vect[i][j];
}
cout <<"第" <<j <<"列元素之和为" <<sum[j] <<endl;
}
int maxsum = sum[0];
for(int i=1; i<6; ++i) {
if (maxsum<sum[i])
maxsum = sum[i];
}
cout <<"列元素和最大为" <<maxsum <<endl;
}
Ⅶ [计算机][c语言][编程] 跪求c语言标准库函数的详解(高手请进)!邮箱:[email protected]
推荐:
1.C语言编程宝典
2.C In China
3.网络C语言吧
4.编程中国
5.C语言之家
6.C语言基地
c语言基地 有名校教师 视频 教学
我认为要学好C语言首先必须了解等级考试C语言的大纲和内容,以及各种辅助材料的用途,这是学好C的基础。从以前的经验以及考网上的一些信息可知,要自学C语言必须准备以下资料:
1、 教材:大家现在都公认是清华大学谭浩强主编的那本,当然有其他的也可以,如高校出版社的。
2、 习题集:我认为清华大学的《C语言样题汇编》不错。书后面附有答案。
3、 上机练习:我认为南开大学的那个可以,最好是在考前从头到尾做一遍。答案可以去考网下载区下载。
4、 大纲:这个肯定要的,可以在考网二级版那里去下,然后打印出来。
5、 自学计划:为了做到有计划有目的地学习C语言,大家可以根据自己的学习(或工作)情况,制定一个自学计划,循序渐进地学习。
6、 模拟盘:为了更好地熟悉考场环境,下一个模拟盘是必不可少的,可以在。下载,注意,在下载时要把锁匙盘一起下回来,否则不能进入考试环境。
7、 教学光盘:如果能买到C语言的教学光盘,那当然更好,这样可以更直观地学习C语言了。
下面从微观上针对C语言的几个重点和难点,逐个谈谈具体的自学方法。
二 如何学习C语言的运算符和运算顺序
C语言的运算功能十分丰富,运算种类远多于其它程序设计语言。因此,当多种不同运算组成一个运算表达式,即一个运算式中出现多种运算符时,运算的优先顺序和结合规则显得十分重要。
初学者往往对此感到非常困难,觉得C语言学习太繁杂,其实只要我们对此合理进行分类,找出它们与我们在数学中所学到运算之间的不同点之后,记住这些运算也就不困难了,有些运算符在理解后更会牢记心中,将来用起来得心应手,而有些可暂时放弃不记,等用到时再记不迟。
下面是所有的运算符按优先级不同分类列表:(对不起,因为表格显示不正常,已被我删除大家可以看书上的)
表中列出15种优先级的运算符,从高到低,优先级为1 ~ 15,最后边一栏是结合规则,除第2、3级和第14级为从右至左结合外,其它都是从左至右结合,它决定同级运算符的运算顺序。
下面我们通过几个例子来说明:
(1) 3*20/4%10 这个表达式中出现3种运算符,是同级运算符,运算顺序按从左至右结合,因此先计算3 * 20=60,然后被4除,结果为15,最后是%(求余数)运算,所以表达式的最终结果为15%10 = 5
(2)a = 3;b = 5;c =++ a* b ;d =a + +* b;
例子中的“;”是C语言的语句分隔符,执行顺序为从左到右,第1条语句执行后a的值为3,第2条语句执行后b的值为5,第3条语句中有两个运算符前置+ +和*,按表中所列顺序,+ +先执行,*后执行,所以+ + a执行后,a的值为4,由于+ +为前置运算,所以a的值4参与运算,C的值为20,最后执行第4条语句,由于a + +为后置运算,所以a值为4参与运算,使得d的值仍为20,而a参与运算后其值加1,值为5。
这个例子执行后,a的值为5,b的值为5,c的值为20,d的值也是20。
(3)a = 3,b = 5,b+ = a,c = b* 5
例子中的“,”是逗号结合运算,上式称为逗号表达式,自左向右结合,最后一个表达式的结果值就是逗号表达式的结果,所以上面的逗号表达式结果为40,a的值为3,b的值为8,c的值为40。
三、如何学习C语言的四种程序结构
(1)顺序结构
这种结构的程序比较简单,就是按照语句的排列顺序依次执行的机制。顺序结构的执行顺序是自上而下,依次执行,因此编写程序也必须遵守这一规定,否则你的程序执行结果就不对。
例如;a = 3,b = 5,现交换a,b的值,正确的程序为:
c = a;
a = b;
b = c;
执行结果是a = 5,b = c = 3如果改变其顺序,写成:
a = b;
c = a;
b = c;
则执行结果就变成a = b = c = 5,不能达到预期的目的,这是初学者常犯的错误。
顺序结构可以独立使用构成一个简单的完整程序,常见的输入、计算,输出三步曲的程序就是顺序结构,例如计算圆的面积,其程序的语句顺序就是输入圆的半径R,计算S = 3.14159*R*R,输出圆的面积S。而大多数情况下顺序结构都是作为程序的一部分,与其它结构一起构成一个复杂的程序,例如分支结构中的块体、循环结构中的循环体等。
C语言自学方法(2)
(2) 分支结构
分支结构与顺序结构不同,其执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。分支结构的程序设计方法的关键在于构造合适的分支条件和分析程序流程,根据不同的程序流程选择适当的分支语句。
分支结构适合于带有逻辑条件判断的计算,设计这类程序时往往都要先绘制其程序流程图,然后根据程序流程写出源程序,这样做把程序设计分析与语言分开,使得问题简单化,易于理解。程序流程图是根据解题分析所绘制的程序执行流程图。
学习分支结构不要被分支嵌套所迷惑,只要弄清基本的分支结构,嵌套结构也就不难了。嵌套只不过是分支块体中又包括分支语句而已,不是新知识,只要你基础知识扎实,分支嵌套也难不住你,下面我们重点讨论几种基本的分支结构的学习方法。
①If(条件)
{
块
}
这种分支结构中的块可以是一条语句,此时“{
}”可以省略,也可以是多条语句。它有两条分支路径可选,一条是条件为真,执行块,另一条是条件不满足,跳过块。
如,计算x的绝对值,根据绝对值定义,我们知道,当x>=0时,其绝对值不变,而x<0时其绝对值是为x的反号,因此程序段为:if(x<0)
x=-x;
②if(条件)
else
这是典型的分支结构,如果条件成立,执行块1,否则执行块2,块1和块2都有1条或若干条语句构成。
如:求ax^2+bx+c=0的根
分析:因为当b^2-4ac>=0时,方程有两个实根,否则(b^2-4ac<0)有两个共轭复根。其程序段如下:
d=b*b-4*a*c;
if(d>=0)
{x1=(-b+sqrt(d))/2a;
x1=(-b-sqrt(d))/2a;
printf(“x1=%8.4f,x2=%8.4f\n”,x1,x2);
}
else
{r=-b/(2*a);
i =sqrt(-d)/(2*a);
printf(“x1=%8.4f+%8.4fi\n”r, i);
printf(“x2=%8.4f-%8.4fi\n”r,i)
}
③多路分支:其语句格式为:
if(条件1) ;
else if(条件2)
else if(条件3)
……
else if(条件n)
else
④switch语句:
switch
语句也是多分支选择语句,又称为多路开关语句,到底执行哪一块,取决于开关设置,也就是表达式的值与常量表达式相匹配的那一路,它不同if—else 语句,它的所有分支都是并列的,程序执行时,由第一分支开始查找,如果相匹配,执行其后的块,接着执行第2分支,第3分支……的块,直到遇到break语句;如果不匹配,查找下一个分支是否匹配。
(3)循环结构:
循环结构可以减少源程序重复书写的工作量,用来描述重复执行某段算法的问题,这是程序设计中最能发挥计算机特长的程序结构,C语言中提供四种循环,即goto循环、while循环、do –while循环和for循环。
四种循环可以用来处理同一问题,一般情况下它们可以互相代替换,但一般不提昌用goto循环,所以下面我们重点讲解另外的三种循环。
常用的三种循环结构学习的重点在于弄清它们相同与不同之处,以便在不同场合下使用,大家好好看一下书中三种循环的格式和执行顺序,如何替换使用,如把while循环的例题,用for语句重新编写一个程序,这样能更好地理解它们的作用。
注意:在while和do—while循环体内和for
循环中的第3语句中,应包含趋于结束的语句(如I++,I--),否则就可能成了一个死循环,这也是初学者的一个常见错误。
下面我们来讨论下这三种循环的异同之处:
用while和do—while循环时,循环变量的初始化的操作应在循环体之前,而for循环是在语句1中进行的;while
循环和for循环都是先判断表达式,后执行循环体,而do—while循环是先执行循环体后判断表达式,也就是说do—while的循环体最少被执行一次,而while
循环和for就不一定了。这三种循环都可以用break语句跳出循环,用continue语句结束本次循环,而goto语句与if构成的循环,不能用break和
continue语句进行控制。
这三种结构并不是彼此孤立的,在循环中可能出现分支、顺序结构,分支中也可能出现循环、顺序结构而把循环、分支看成一个语句,它又是构成顺序结构的一个元素,因此这三种结构相互结合,就能实现各种算法,设计出解题程序,但若是很大的题目,这样编出的程序往往很长,重复结构多,并且可阅读性差,因此我们常将C程序设计成模块化结构。
(4)模块化程序结构
C语言的模块化程序结构用函数来实现,即将复杂的C程序分为若干模块,每个模块都编写成一个合法的C函数,然后用主函数调用函数及函数调用函数实现一大C程序:C程序=主函(main)+若干个函数。
在程序设计中,常将一些常用的功能模块写成函数,也可以将大程序段分割成若干函数,前者目的在于减少重复编写程序段的工作量,后者目的在于缩短模块长度,以便程序阅读方便。
一个源程序文件由一个或多个函数组成,它是一个编译单位,而一个C程序由一个或多个源程序文件组成。对较大的程序,往往分成多个文件,这样可以分别编写、分别编译,提高高调试效率,一个源程序文件可以被多个C程序公用。
C程序的的执行是从main()函数开始,调用其它函数后流程回到main函数,在main中结束整个函数运行,main函数的称是系统规定的,用户可以修改其内容即函数体,但不能修改其名称和参数,一个C程序必须有一个main函数,也只能有一个main函数。
所有函数都是平行的,即在定义函数时是互相独立的一个函数度不从属于另一个函数,即函数不能嵌套定义,但可以互相调用,但不能调用main函数。
函数分成两类,即标准函数和用户自定义函数,标准函数又称库函数,由系统提供,用户可直接调用,C语言提供了丰富的库函数,请考生在编写C程序时查阅教材后的函数说明,这可节省你的编程工作量;用户自定义函数由编程者自己编写.
回答者:阿拉蕾啊呀 - 试用期 一级 7-23 11:13
提问者对于答案的评价:
太好了,非常感谢!
评价已经被关闭 目前有 1 个人评价
好
100% (1) 不好
0% (0)
对最佳答案的评论
19798802 C语言新手群快加入吧!!!!!!1
评论者: 549045259 - 见习魔法师 二级
浮躁的人容易问:我到底该学什么;----别问,学就对了;浮躁的人容易说:我要中文版!我英文不行!----不行?学呀!浮躁的人分两种:只观望而不学的人;只学而不坚持的人;浮躁的人永远不是一个高手。
评论者: hnytgl - 试用期 一级
其他回答共 4 条
1.读代码!
2.改代码!
3.写代码!
回答者:liuding1213 - 见习魔法师 二级 7-18 21:10
找一本经典教材,例如谭浩强的《C语言陈序设计》。
找一本习题集,要有全部详细解释的那种,最好有实例的代码答案。
花一个月把课本看完,务求理解。不理解的地方也不要死抠,做上标记等以后再解决。然后开始做题,不要因为题目简单就放过,往往简单背后蕴藏大的发现。也可以快速看完书,然后复习,每复习完一章后把习题集上的题目好好做一遍。
做题时最好在计算机上把不明白的地方亲自实践一下,然后在笔记本上写下自己的感想和心得。考试前翻一翻笔记即可。
千里之行始于足下,行动吧!
你的串号我已经记下,采纳后我会帮你制作
Ⅷ C++标准库是什么
C++标准库,C++ Standard Library,是类库和函数的集合,其使用核心语言写成,由c++标准委员会制定,并不断维护更新。
C++强大的功能来源于其丰富的类库及库函数资源。在C++开发中,要尽可能地利用标准库完成。
这样做的直接好处包括:
1、成本:
已经作为标准提供,不必再花费时间、人力重新开发。
2、质量:
标准库的都是经过严格测试的,正确性有保证。
3、效率:
关于人的效率已经体现在成本中了,关于代码的执行效率要相信实现标准库的前辈的水平。
4、良好的编程风格:
采用行业中普遍的做法进行开发。
(8)编程标准库扩展阅读
C++语言特点
1、支持数据封装和数据隐藏
在C++中,类是支持数据封装的工具,对象则是数据封装的实现。C++通过建立用户定义类支持数据封装和数据隐藏。
2、支持继承和重用
在C++现有类的基础上可以声明新类型,这就是继承和重用的思想。通过继承和重用可以更有效地组织程序结构,明确类间关系,并且充分利用已有的类来完成更复杂、深入的开发。新定义的类为子类,成为派生类。它可以从父类那里继承所有非私有的属性和方法,作为自己的成员。
3、支持多态性
采用多态性为每个类指定表现行为。多态性形成由父类和它们的子类组成的一个树型结构。在这个树中的每个子类可以接收一个或多个具有相同名字的消息。当一个消息被这个树中一个类的一个对象接收时,这个对象动态地决定给予子类对象的消息的某种用法。多态性的这一特性允许使用高级抽象。
Ⅸ C语言标准库和C++标准库有什么不同
二者区别主要定义为功能性的不同,c语言库用于开发系统为主,C++的高级特新对于开发大型项目有辅,所以你得根据实际情况去分析使用库,你也可以搭建自己的库
Ⅹ c++编程中,类的声明文件和实现文件为什么都要包含标准库
因为这类文件或者说我们写的头文件都要
#pragma once
或者
#ifndef
#define
#end,,,这样来避免文件被多次包含