| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 524 人关注过本帖
标题:[求助]想问下C语言怎么进阶
收藏  订阅  推荐  打印 
beric
Rank: 1
等级:新手上路
帖子:3
积分:130
注册:2007-8-1
[求助]想问下C语言怎么进阶

RT
我已学完了C语言了,数据结构也学了
有天别人问我会不会编小游戏和小软件之类的
我觉得根本都不会,自己就会写几个题目而已
我想问下学完C语言的基础后,还要看些什么书才能懂编软件和小游戏之类的
我觉得对那些都没有什么感觉,不知道从何下手
请大师们指点指点
和我讲讲C语言是怎么从入门到编软件之类的(就是说我看些什么书之类的)
谢谢各位了
搜索更多相关主题的帖子: 小游戏  软件  进阶  C语言  大师  
2007-8-1 23:59
czl
Rank: 2
等级:注册会员
帖子:50
积分:600
注册:2007-7-1

我也碰到这方面的问题了 我的方法是看别人源程序 必要的时候写注释 并进行修改
挑一些有代表的就好

2007-8-2 00:10
卧龙孔明
Rank: 12Rank: 12Rank: 12
等级:版主
威望:47
帖子:3702
积分:39046
注册:2006-10-13

看看中断和图形库

为了中国软件工业的未来,有爱心的朋友请不要帮忙代做作业,或者至少是收费服务!如果您不需要钱,或者您不愿收费用于自己,请把收取的钱用于支援山区贫困学生…谢谢大家!
2007-8-2 09:25
Biglon
Rank: 1
等级:新手上路
帖子:20
积分:300
注册:2007-8-2

看别人的源程序,要有点难度的!!

或是学高级C编程之类
2007-8-2 11:32
zklhp
Rank: 12Rank: 12Rank: 12
来自:china
等级:版主
威望:8
帖子:728
积分:8549
注册:2007-7-10

以下是引用Biglon在2007-8-2 11:32:42的发言:
看别人的源程序,要有点难度的!!

或是学高级C编程之类

高级C编程 是啥样的?


程序会写,就是写起来费劲,
代码会看,就是看起来要参考,
道理懂得,就是懂得一知半解,半瓶子醋,
能说会道,就是原理懂得,懂得不深,
啥都知道,就是不知道到底自己知道什么。
2007-8-2 16:32
anelwl
Rank: 2
等级:注册会员
帖子:70
积分:800
注册:2007-7-26

觉得最有效的方法是看别人编的游戏或程序代码

2007-8-2 16:34
m197002846
Rank: 1
等级:新手上路
帖子:23
积分:330
注册:2007-7-31

看看有关的视频

2007-8-2 16:52
卧龙孔明
Rank: 12Rank: 12Rank: 12
等级:版主
威望:47
帖子:3702
积分:39046
注册:2006-10-13

进阶是比初学皮毛困难的多的,因为资料缺乏,内容深奥
给你个代码:
#include<math.h>
#include<mem.h>
#include<dos.h>
#include<stdlib.h>

#define p_num 2000

struct _Particle
{
float vx,vy,ax,ay,x,y;
unsigned char c;
};

void SetColor(int c,int r,int g,int b)
{
outportb(0x3c6,255);
outportb(0x3c8,c);
outportb(0x3c9,r>>2);
outportb(0x3c9,g>>2);
outportb(0x3c9,b>>2);
}

char far *GetBuffer(long x,long y)
{
return (char far *)(0xa0000000L+x+y*320);
}

void blur()
{
unsigned char far *p, far *q;
for(p=GetBuffer(1,1),q=GetBuffer(318,198);p<q;p++) *p=*(p-1)+*(p+1)+*(p-320)+*(p+320)>>2;
}

void main()
{
struct _Particle pg[p_num];
float fcos,fsin,t=0.01,angle=0.0;
float RGB[256][3];
int i;
int dx,dy;

memset(pg,0,p_num*sizeof(struct _Particle));
for(i=0;i<p_num;i++)
{
pg[i].x=160;
pg[i].y=100;
pg[i].c=255;
pg[i].ax=rand()%10191/1000.0-5;
pg[i].ay=rand()%8191/1000.0-4;
}
for(i=0;i<256;i++) RGB[i][0]=sqrt(i)/16.0;
for(i=0;i<256;i++) RGB[i][1]=pow(i,0.7)/48.5;
for(i=0;i<256;i++) RGB[i][2]=(i*i)/65536.0;

_AX=0x13;
asm int 0x10;

for(i=0;i<256;i++) SetColor(i,RGB[i][0]*256,RGB[i][1]*256,RGB[i][2]*256);

while(inportb(0x60)!=1)
{
fcos=cos(angle);
fsin=sin(angle);
for(i=0;i<p_num;i++)
{
pg[i].vx+=pg[i].ax*t;
pg[i].vy+=pg[i].ay*t;
pg[i].x+=pg[i].vx*t;
pg[i].y+=pg[i].vy*t;
dx=(pg[i].x-160)*fcos-(100-pg[i].y)*fsin+160;
dy=(pg[i].x-160)*fsin+(100-pg[i].y)*fcos+100;
if(dx>0&&dx<319&&dy>0&&dy<199) *GetBuffer(dx,dy)=pg[i].c;
if(dx<0||dx>=320) pg[i].vx=-pg[i].vx;
if(dy<0||dy>=200) pg[i].vy=-pg[i].vy;
}
blur();
angle+=0.01;
}

_AX=0x03;
asm int 0x10;
}

在Win-TC 或TC下运行,如果某日你能完全读懂它,那你就相当于进阶了


为了中国软件工业的未来,有爱心的朋友请不要帮忙代做作业,或者至少是收费服务!如果您不需要钱,或者您不愿收费用于自己,请把收取的钱用于支援山区贫困学生…谢谢大家!
2007-8-3 07:52
beric
Rank: 1
等级:新手上路
帖子:3
积分:130
注册:2007-8-1

以下是引用卧龙孔明在2007-8-3 7:52:19的发言:

进阶是比初学皮毛困难的多的,因为资料缺乏,内容深奥
给你个代码:
#include<math.h>
#include<mem.h>
#include<dos.h>
#include<stdlib.h>

#define p_num 2000

struct _Particle
{
float vx,vy,ax,ay,x,y;
unsigned char c;
};

void SetColor(int c,int r,int g,int b)
{
outportb(0x3c6,255);
outportb(0x3c8,c);
outportb(0x3c9,r>>2);
outportb(0x3c9,g>>2);
outportb(0x3c9,b>>2);
}

char far *GetBuffer(long x,long y)
{
return (char far *)(0xa0000000L+x+y*320);
}

void blur()
{
unsigned char far *p, far *q;
for(p=GetBuffer(1,1),q=GetBuffer(318,198);p<q;p++) *p=*(p-1)+*(p+1)+*(p-320)+*(p+320)>>2;
}

void main()
{
struct _Particle pg[p_num];
float fcos,fsin,t=0.01,angle=0.0;
float RGB[256][3];
int i;
int dx,dy;

memset(pg,0,p_num*sizeof(struct _Particle));
for(i=0;i<p_num;i++)
{
pg[i].x=160;
pg[i].y=100;
pg[i].c=255;
pg[i].ax=rand()%10191/1000.0-5;
pg[i].ay=rand()%8191/1000.0-4;
}
for(i=0;i<256;i++) RGB[i][0]=sqrt(i)/16.0;
for(i=0;i<256;i++) RGB[i][1]=pow(i,0.7)/48.5;
for(i=0;i<256;i++) RGB[i][2]=(i*i)/65536.0;

_AX=0x13;
asm int 0x10;

for(i=0;i<256;i++) SetColor(i,RGB[i][0]*256,RGB[i][1]*256,RGB[i][2]*256);

while(inportb(0x60)!=1)
{
fcos=cos(angle);
fsin=sin(angle);
for(i=0;i<p_num;i++)
{
pg[i].vx+=pg[i].ax*t;
pg[i].vy+=pg[i].ay*t;
pg[i].x+=pg[i].vx*t;
pg[i].y+=pg[i].vy*t;
dx=(pg[i].x-160)*fcos-(100-pg[i].y)*fsin+160;
dy=(pg[i].x-160)*fsin+(100-pg[i].y)*fcos+100;
if(dx>0&&dx<319&&dy>0&&dy<199) *GetBuffer(dx,dy)=pg[i].c;
if(dx<0||dx>=320) pg[i].vx=-pg[i].vx;
if(dy<0||dy>=200) pg[i].vy=-pg[i].vy;
}
blur();
angle+=0.01;
}

_AX=0x03;
asm int 0x10;
}

在Win-TC 或TC下运行,如果某日你能完全读懂它,那你就相当于进阶了

多谢大家啊,不过要写=出一个大的程序和软件,要具体看什么书啊,不然现在这样还是有些不懂下手

2007-8-5 19:22
xieyuanchang
Rank: 1
等级:新手上路
帖子:23
积分:330
注册:2007-8-5

#include<mem.h>
这个头文件是啥?我的vc没有..

2007-8-5 19:40
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.064571 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved