当前位置:首页 » 编程软件 » 编程简单示范

编程简单示范

发布时间: 2025-04-07 05:46:25

1. 当0≤X≤255时,单片机如何用查表法编程求Y=X²

很好处理呀,首先这个表应该做成16位的,用C的话就简单了,下面用汇编做个示范:
DEAL:
MOV DPTR,#TAB
MOV A,R0
RLC A
JC DEALH
PUSH ACC ;X<128时直接查表
MOVC A,@A+DPTR
MOV R2,A
POP ACC
INC A
MOVC A,@A+DPTR
MOV R3,A
RET
DEALH: ;当X大于127时的处理,此时DPH+1
INC DPH
PUSH ACC
MOVC A,@A+DPTR
MOV R2,A
POP ACC
INC A
MOVC A,@A+DPTR
MOV R3,A
RET
;表你自己补充全
TAB:
DW 0,1,4,9,16,25,36,49,64,81,100
DW ...............

2. for的for循环(计算机编程)

for( ; ; )里面是3个语句,两个分号。第一个语句是开始前执行,第二个语句是判断真假,如果真,就执行后面(大括号内)的代码。第三个语句是每次执行完毕后执行的东西,通常第三个语句使用i++表示i=i+1的意思,用来递增自变量i。
比如:
最常用的 for(inti=0;i<10;i++){//i-=3跟i=i-3效果相同printf(i=%d ,i);}递减式for for(inti=10;i>0;i-=3){//i-=3跟i=i-3效果相同printf(i=%d ,i);}递增式for for(inti=10;i>0;i+=3){//i+=3跟i=i+3效果相同printf(i=%d ,i);} 语法:
(1)for循环 for(inti=0;i<10;i++){statements;} 语法
for(initialize;test;increment){
statement
}
示例
例1:循环1到100的值 <scripttype=text/javascript>varValue=0;for(vara=1;a<=100;a++){Value=Value+a;Value+=<br>;}document.write(Value);</script>例2:js输出九九乘法表 <scripttype=text/javascript>varbdqnyhb=for(vari=1;i<=9;i++){for(varj=1;j<=i;j++){bdqnyhb+=i+×+j+=+i*j+;}bdqnyhb+=<br>;}document.write(bdqnyhb);</script>JS另有for..in..语句。 Java的for语句形式有两种:一种是和c语言中的for语句形式一样,另一种形式用于在集合和数组之中进行迭代。有时候把这种形式称为增强型的for(enhanced for)语句,它可以使循环更加紧凑和容易阅读。
示例
为了演示,参考下面的数组,它保存数字1到10:
int[] numbers = {1,2,3,4,5,6,7,8,9,10};
下面的程序EnhancedForDemo使用增强for循环遍历这个数组: publicclassEnhancedForDemo{publicstaticvoidmain(String[]args){int[]numbers={1,2,3,4,5,6,7,8,9,10};for(intitem:numbers){System.out.println(Countis:+item);}}}在这个例子中,变量item保存从数字数组获得的当前值。
Count is :1
Count is :2
Count is :3
Count is :4
Count is :5
Count is :6
Count is :7
Count is :8
Count is :9
Count is :10
建议在情况允许的条件下,使用for语句的这种形式,而不使用其一般形式。 for 循环变量:
=初始值 to 终止值 do 语句内容
或者
for 循环变量:=初始值 downto 终止值 do 语句内容
其他内容与C的相同,此处省略。
循环语句的含义在于从“控制变量”等于“初值”开始,循环到“终值”,当“控制变量”的值:
(1) to:大于终值时,终止循环。这里相当于BASIC中STEP(步长)=1的情况。
(2) downto:小于终值时,终止循环。这里相当于BASIC中STEP(步长)=-1的情况。
示例一(to)
按顺序输出1~100: fori:=1tondowrite(i,'');输出值为:1 2 3 4 5 6 …… 98 99 100
示例二(downto)
按倒序输出1~100 forI:=100downto1dowrite(i,'');输出值为:100 99 98 97 …… 3 2 1
注意:单个语句可直接用for循环变量:=初始值 to 终止值 do 语句内容,但有多个语句时要加
“begin“和”end“。
格式为:
for 循环变量:=初始值 to/downto 终止值 do
语句内容1;
语句内容2;
……
语句内容n;
end; FOR 循环变量=初始值 TO 终止值 STEP步长
语句内容
NEXT循环变量
其他内容与C的相同,此处亦省略。
C语言语法
只要指定条件为 true 都执行语句块。
for(initialization; test; increment)
statements
参数
initialization
必选项。一个表达式。该表达式只在执行循环前被执行一次。
test
必选项。一个 Boolean表达式。如果 test 是 true,则 statement 被执行。如果 test 是 false,则循环结束。
increment
可选项。一个表达式。在每次经过循环的最后执行该递增(减)表达式。
statements
可选项。test 是 true 时,要执行的一个或多个语句。可以是复合语句。
说明
循环要执行确定的次数,通常使用for循环。
示例
下面的例子示范了一个for循环。
/* 在开始时 i 被设为 0,并在每次重复的最后被增加 1。
在循环重复前,
如果 i 不小于 10,则循环结束。*/
var myarray = new Array();
for(i = 0; i < 10; i++) {
myarray= i;
在c语言的解释是:
for:循环语句。
作用
循环
它的一般形式为:
for(<初始化>;<条件表达式>;<增量>)
语句
初始化总是一个赋值语句,它用来给循环控制变量赋初值;条件表达式是一个关系表达式,它决定什么时候退出循环;增量定义循环控制变量每循环一次后按什么方式变化。这三个部分之间用;分开。
例如:
for(i=1;i<=10;i++)
语句;
上例中先给i赋初值1,判断i是否小于等于10,若是则执行语句,之后值增加1。再重新判断,直到条件为假,即i>10时,结束循环。
注意:
(1).for循环中语句可以为语句体,但要用{和}将参加循环的语句括起来。
(2).for循环中的初始化、条件表达式和增量都是选择项,即可以缺省,但;不能缺省。省略了初始化,表示不对循环控制变量赋初值。省略了条件表达式,则不做其它处理时便成为死循环。省略了增量,则不对循环控制变量进行操作,这时可在语句体中加入修改循环控制变量的语句。
(3).for循环可以有多层嵌套。
例如:
for(;;) 语句;
for(i=1;;i+=2) 语句;
for(j=5;;) 语句;
这些for循环语句都是正确的。
FOR
field of regard 的缩写LOGO中的FOR
visal basic 示例:
Private Sub Command1_Click()Dim s(1 To 1000) As Singles(1) = 0s(2) = 1For i = 3 To 1000s(i) = 1For j = 2 To i - 1If i Mod j = 0 Then s(i) = 0Next jIf s(i) = 1 Then Print iNext iEnd Sub
(版本不同可能输入方式不同) 控制结构的条件表达式结果可以是任何值,Lua认为false和nil为假,其它值为真。
for语句有两大类:
数值for循环
格式:
for var=exp1,exp2,exp3 do
loop-part
end
for将用exp3作为step从exp1(初始值)到exp2(终止值),执行loop-part。其中exp3可以省略,默认step=1
有几点需要注意:
1. 三个表达式只会被计算一次,并且是在循环开始前。
for i=1,f(x) do
print(i)
end
for i=10,1,-1 do
print(i)
end
第一个例子f(x)只会在循环前被调用一次。
2. 控制变量var是局部变量自动被声明,并且只在循环内有效.
for i=1,10 do
print(i)
end
max = i -- probably wrong! 'i' here is global
如果需要保留控制变量的值,需要在循环中将其保存
-- find a value in a list
local found = nil
fori=1,a.n do
if a[i] == value then
found = i -- save value of 'i'
break
end
end
print(found)
3. 循环过程中不要改变控制变量的值,那样做的结果是不可预知的。如果要退出循环,使用break语句。
范型for循环
-- print all values of array 'a'
格式:for i,v in ipairs(a) do print(v) end
范型for遍历迭代子函数返回的每一个值。
再看一个遍历表key的例子:
-- print all keys of table 't'
for k in pairs(t) do print(k) end
范型for和数值for有两点相同:
1. 控制变量是局部变量
2. 不要修改控制变量的值
再看一个例子,假定有一个表:
days = {Sunday, Monday, Tuesday, Wednesday,
Thursday, Friday, Saturday}
想把对应的名字转换成星期几,一个有效地解决问题的方式是构造一个反向表:
revDays = {[Sunday] = 1, [Monday] = 2,
[Tuesday] = 3, [Wednesday] = 4,
[Thursday] = 5, [Friday] = 6,
[Saturday] = 7}
下面就可以很容易获取问题的答案了:
x = Tuesday
print(revDays[x]) --> 3
我们不需要手工,可以自动构造反向表
revDays = {}
for i,v in ipairs(days) do
revDays[v] = i
end
格式
(FOR 循环变量启动数据终止数据[循环体]步长)
若步长为1,则步长可省略,圆括号可去掉。
当循环结束时,循环变量的值为最后一次符合启动数据至终止数据之间的数值。不是第一次不符合值。
例:FOR X 1 5 [PR 'A] PR :X
显示: A
A
A
A
A
5
并不是5个A和一个6 而是5个A和一个5
这种现象被称为:BAG现象 介绍
对一组文件中的每一个文件执行某个特定命令。
FOR %variable IN (set) DO command [command-parameters]
%variable 指定一个单一字母可替换的参数。
(set) 指定一个或一组文件。可以使用通配符。
command 指定对每个文件执行的命令。
command-parameters
为特定命令指定参数或命令行开关。
在批处理文件中使用 FOR 命令时,指定变量请使用 %%variable而不要用 %variable。变量名称是区分大小写的,所以 %i 不同于 %I.如果命令扩展名被启用,下列额外的 FOR 命令格式会受到支持:
FOR /D %variable IN (set) DO command [command-parameters]
如果集中包含通配符,则指定与目录名匹配,而不与文件名匹配。
FOR /R [[drive:]path] %variable IN (set) DO command [command-parameters]
检查以 [drive:]path 为根的目录树,指向每个目录中的
FOR 语句。如果在 /R 后没有指定目录,则使用当前
目录。如果集仅为一个单点(.)字符,则枚举该目录树。
FOR /L %variable IN (start,step,end) DO command [command-parameters]
该集表示以增量形式从开始到结束的一个数字序列。
因此,(1,1,5) 将产生序列 1 2 3 4 5,(5,-1,1) 将产生
序列 (5 4 3 2 1)。
FOR /F [options] %variable IN (file-set) DO command [command-parameters]
FOR /F [options] %variable IN (string) DO command [command-parameters]
FOR /F [options] %variable IN ('command') DO command [command-parameters]
或者,如果有 usebackq 选项:
FOR /F [options] %variable IN (file-set) DO command [command-parameters]
FOR /F [options] %variable IN (string) DO command [command-parameters]
FOR /F [options] %variable IN ('command') DO command [command-parameters]
filenameset 为一个或多个文件名。继续到 filenameset 中的下一个文件之前,每份文件都已被打开、读取并经过处理。处理包括读取文件,将其分成一行行的文字,然后将每行解析成零或更多的符号。然后用已找到的符号字符串变量值调用 For 循环。以默认方式,/F 通过每个文件的每一行中分开的第一个空白符号。跳过空白行。您可通过指定可选 options参数替代默认解析操作。这个带引号的字符串包括一个或多个指定不同解析选项的关键字。这些关键字为:
eol=c - 指一个行注释字符的结尾(就一个)
skip=n - 指在文件开始时忽略的行数。
delims=xxx - 指分隔符集。这个替换了空格和跳格键的默认分隔符集。
tokens=x,y,m-n - 指每行的哪一个符号被传递到每个迭代的for本身。这会导致额外变量名称的分配。m-n格式为一个范围。通过 nth 符号指定 mth。如果符号字符串中的最后一个字符星号,那么额外的变量将在最后一个符号解析之后分配并接受行的保留文本。
usebackq - 指定新语法已在下类情况中使用:在作为命令执行一个后引号的字符串并且一个单引号字符为文字字符串命令并允许在 filenameset中使用双引号扩起文件名称。
范例
某些范例可能有助:
FOR /F eol=; tokens=2,3* delims=, %i in (myfile.txt) do @echo %i %j %k会分析 myfile.txt 中的每一行,忽略以分号打头的那些行,将每行中的第二个和第三个符号传递给for程序体;用逗号和/或空格定界符号。请注意,这个for程序体的语句引用 %i 来取得第二个符号,引用 %j 来取得第三个符号,引用 %k来取得第三个符号后的所有剩余符号。对于带有空格的文件名,您需要用双引号将文件名括起来。为了用这种方式来使用双引号,您还需要使用 usebackq 选项,否则,双引号会被理解成是用作定义某个要分析的字符串的。%i 专门在for语句中得到说明,%j 和 %k 是通过tokens= 选项专门得到说明的。您可以通过 tokens= 一行指定最多 26 个符号,只要不试图说明一个高于字母 'z' 或'Z' 的变量。请记住,FOR变量是单一字母、分大小写和全局的;而且,同时不能有 52 个以上都在使用中。您还可以在相邻字符串上使用 FOR /F 分析逻辑;方法是,用单引号将括号之间的 filenameset 括起来。这样,该字符串会被当做一个文件中的一个单一输入行。最后,您可以用 FOR /F 命令来分析命令的输出。方法是,将括号之间的 filenameset 变成一个反括字符串。该字符串会被当做命令行,传递到一个子 CMD.EXE,其输出会被抓进内存,并被当作文件分析。
因此,以下例子:
FOR /F usebackq delims== %i IN (`set`) DO @echo %i会枚举当前环境中的环境变量名称。另外,FOR变量参照的替换已被增强。您可以使用下列选项语法:
~I - 删除任何引号(),扩充 %I
%~fI - 将 %I 扩充到一个完全合格的路径名
%~dI - 仅将 %I 扩充到一个驱动器号
%~pI - 仅将 %I 扩充到一个路径
%~nI - 仅将 %I 扩充到一个文件名
%~xI - 仅将 %I 扩充到一个文件扩展名
%~sI - 扩充的路径只含有短名
%~aI - 将 %I 扩充到文件的文件属性
%~tI - 将 %I 扩充到文件的日期/时间
%~zI - 将 %I 扩充到文件的大小
%~$PATH:I - 查找列在路径环境变量的目录,并将 %I 扩充
到找到的第一个完全合格的名称。如果环境变量名
未被定义,或者没有找到文件,此组合键会扩充到
空字符串
可以组合修饰符来得到多重结果:
%~dpI - 仅将 %I 扩充到一个驱动器号和路径
%~nxI - 仅将 %I 扩充到一个文件名和扩展名
%~fsI - 仅将 %I 扩充到一个带有短名的完整路径名
%~dp$PATH:i - 查找列在路径环境变量的目录,并将 %I 扩充
到找到的第一个驱动器号和路径。
%~ftzaI - 将 %I 扩充到类似输出线路的 DIR
在以上例子中,%I 和 PATH 可用其他有效数值代替。%~ 语法
用一个有效的 FOR变量名终止。选取类似 %I 的大写变量名
比较易读,而且避免与不分大小写的组合键混淆。
使用For输出目录名而忽略文件:
@echo off
for/d %%i in (window?) do @echo %%i
pause for counter = start to end step = 步进
执行语句
next
这个语句的具体解释是指定,执行命令的次数。
具体例子如下
set wshshell=wscript.createobject(wscript.shell) '定义vbs对象
dim num,wen ’创建变量
wen = inputbox(请输入要轰炸的内容必须是英文要不然会报错哦(^o^)/~,发送消息的按键必须是回车键)
num = cint(inputbox(请输入要轰炸的次数必须是数字!!)) '将字符串转化为数字
msgbox 欢迎使用qq炸弹你有10秒的时间定位要轰炸qq的对话框
wscript.sleep 10000
const i=1
for k= i to num ‘步进为1默认,开始次数1,循环次数num变量等等待用户输入
wshshell.sendkeys wen ’发送用户输入的消息
wshshell.sendkeys {ENTER}
wscript.sleep 100
next

3. C语言程序运行的基本步骤是什么

运行程序步骤:

1.编辑:输入源程序并存盘(.C)

2.编译:将源程序翻译为目标文件(.OBJ)

3.链接:将目标文件生成可执行文件( .EXE)

4.运行:执行.EXE文件,得到运行结果。

上机1 C语言简单程序的编写和调试


拓展资料:

C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。c 语言应用程序上机过程具体步骤如下:

打开VC++ 6.0程序 2、点“文件”,“新建“。

在新建页面上选择文件→C++ Source File 并在右边编辑文件名称,选择保存位置,确定。

简单程序示范。

鼠标右键Compile(Ctrl+F7)如图,确定两次,注意下方可查看错误,可上下拉动。确定无错之后,右键Build(F7)如图,同样注意下方是否出现问题,最后右键BuildExecute(Ctrl+F5)。完成。

4. C语言中 绝对值 怎么表示

方法一:用C语言中自带的绝对值函数表示:

如果a是整数:

#include<stdio.h>

#include<math.h>

int a=100,b;

b=abs(a);

printf("%d",b);

如果a是浮点数:

#include<stdio.h>

#include<math.h>

float a=99.9;

float b;

b=fabs(a);

printf("%f",b);

方法二:自己编写一个函数表示:

#include <stdio.h>

int abs(int t)

{

if (t>困颂0)

return t;袜银

else

return -t;

}

int main()

{

int t = 0;

scanf("%d",&t);

printf("%d"告尺宴,abs(t));

return 0;

}

以上两种方法均可以实现求得绝对值。但使用abs函数时,需要将头文件#include<math.h>包含到源文件中。

(4)编程简单示范扩展阅读:

在C语言中,绝对值可以用库函数fabs或abs来表示。

fabs表示对double型数据取绝对值。

abs表示对int型数据取绝对值。

函数原型是:double fabs(double x)。

5. 如何使用python为Hadoop编写一个简单的MapRece程序

MichaelG.Noll在他的Blog中提到如何在Hadoop中用Python编写MapRece程序,韩国的gogamza在其Bolg中也提到如何用C编汪瞎写MapRece程序(我稍微修改了一下原程序,因为他的Map对单词切分使用tab键)。我合并他们两人的文章,也让国内的Hadoop用户能够使用别的语言来编写MapRece程序。首先您得配好您的Hadoop集群,这方面的介绍网上比较多,这儿给个链接(Hadoop学习笔记二安装部署)。HadoopStreaming帮助返锋我们用非Java的编程语言使用MapRece,Streaming用STDIN(标准输入)和STDOUT(标准输出)来和我们编写的Map和Rece进行数据的交换数据。任何能够使用STDIN和STDOUT都可以用来编写MapRece程序,比如我们用Python的sys.stdin和sys.stdout,或者是C中的stdin和stdout。我们还是使用Hadoop的例子WordCount来做示范如何编写MapRece,在WordCount的例子中漏陵晌我们要解决计算在一批文档中每一个单词的出现频率。首先我们在Map程序中会接受到这批文档每一行的数据,然后我们编写的Map程序把这一行按空格切开成一个数组。并对这个数组遍历按"1"用标准的输出输出来,代表这个单词出现了一次。在Rece中我们来统计单词的出现频率。PythonCodeMap:mapper.py#!/usr/bin/envpythonimportsys#={}#inputcomesfromSTDIN(standardinput)forlineinsys.stdin:#=line.strip()#=filter(lambdaword:word,line.split())#:#writetheresultstoSTDOUT(standardoutput);##Recestep,i.e.theinputforrecer.py##tab-delimited;thetrivialwordcountis1print'%s\t%s'%(word,1)Rece:recer.py#!/usr/bin/#={}#.stdin:#=line.strip()#parsetheinputwegotfrommapper.pyword,count=line.split()#convertcount(currentlyastring)tointtry:count=int(count)word2count[word]=word2count.get(word,0)+countexceptValueError:#countwasnotanumber,sosilently#ignore/discardthislinepass#sortthewordslexigraphically;##thisstepisNOTrequired,wejustdoitsothatour##wordcountexamplessorted_word2count=sorted(word2count.items(),key=itemgetter(0))#writetheresultstoSTDOUT(standardoutput)forword,countinsorted_word2count:print'%s\t%s'%(word,count)CCodeMap:Mapper.c#include#include#include#include#defineBUF_SIZE2048#defineDELIM"\n"intmain(intargc,char*argv[]){charbuffer[BUF_SIZE];while(fgets(buffer,BUF_SIZE-1,stdin)){intlen=strlen(buffer);if(buffer[len-1]=='\n')buffer[len-1]=0;char*querys=index(buffer,'');char*query=NULL;if(querys==NULL)continue;querys+=1;/*nottoinclude'\t'*/query=strtok(buffer,"");while(query){printf("%s\t1\n",query);query=strtok(NULL,"");}}return0;}h>h>h>h>Rece:Recer.c#include#include#include#include#defineBUFFER_SIZE1024#defineDELIM"\t"intmain(intargc,char*argv[]){charstrLastKey[BUFFER_SIZE];charstrLine[BUFFER_SIZE];intcount=0;*strLastKey='\0';*strLine='\0';while(fgets(strLine,BUFFER_SIZE-1,stdin)){char*strCurrKey=NULL;char*strCurrNum=NULL;strCurrKey=strtok(strLine,DELIM);strCurrNum=strtok(NULL,DELIM);/*necessarytocheckerrorbut.*/if(strLastKey[0]=='\0'){strcpy(strLastKey,strCurrKey);}if(strcmp(strCurrKey,strLastKey)){printf("%s\t%d\n",strLastKey,count);count=atoi(strCurrNum);}else{count+=atoi(strCurrNum);}strcpy(strLastKey,strCurrKey);}printf("%s\t%d\n",strLastKey,count);/*flushthecount*/return0;}h>h>h>h>首先我们调试一下源码:chmod+xmapper.pychmod+xrecer.pyecho"foofooquuxlabsfoobarquux"|./mapper.py|./recer.pybar1foo3labs1quux2g++Mapper.c-oMapperg++Recer.c-oRecerchmod+xMapperchmod+xRecerecho"foofooquuxlabsfoobarquux"|./Mapper|./你可能看到C的输出和Python的不一样,因为Python是把他放在词典里了.我们在Hadoop时,会对这进行排序,然后相同的单词会连续在标准输出中输出.在Hadoop中运行程序首先我们要下载我们的测试文档wget页面中摘下的用php编写的MapRece程序,供php程序员参考:Map:mapper.php#!/usr/bin/php$word2count=array();//inputcomesfromSTDIN(standardinput)while(($line=fgets(STDIN))!==false){//$line=strtolower(trim($line));//$words=preg_split('/\W/',$line,0,PREG_SPLIT_NO_EMPTY);//increasecountersforeach($wordsas$word){$word2count[$word]+=1;}}//writetheresultstoSTDOUT(standardoutput)////Recestep,i.e.theinputforrecer.pyforeach($word2countas$word=>$count){//tab-delimitedecho$word,chr(9),$count,PHP_EOL;}?>Rece:mapper.php#!/usr/bin/php$word2count=array();//inputcomesfromSTDINwhile(($line=fgets(STDIN))!==false){//$line=trim($line);//parsetheinputwegotfrommapper.phplist($word,$count)=explode(chr(9),$line);//convertcount(currentlyastring)toint$count=intval($count);//sumcountsif($count>0)$word2count[$word]+=$count;}//sortthewordslexigraphically////thissetisNOTrequired,wejustdoitsothatour////wordcountexamplesksort($word2count);//writetheresultstoSTDOUT(standardoutput)foreach($word2countas$word=>$count){echo$word,chr(9),$count,PHP_EOL;}?>作者:马士华发表于:2008-03-05

热点内容
1t机械缓存 发布:2025-04-09 10:33:24 浏览:998
建造师加密狗 发布:2025-04-09 10:24:07 浏览:261
java爬虫源码 发布:2025-04-09 10:23:53 浏览:415
速迅安卓哪里下载 发布:2025-04-09 10:23:14 浏览:522
c语言公式计算 发布:2025-04-09 10:09:07 浏览:558
php数组下标排序 发布:2025-04-09 09:57:19 浏览:853
服务器python 发布:2025-04-09 09:48:09 浏览:561
压缩袋抽多久 发布:2025-04-09 09:45:53 浏览:163
phpqq分享 发布:2025-04-09 09:02:45 浏览:354
sql虚拟列 发布:2025-04-09 08:59:36 浏览:85