if then else end if
时间: 2023-04-27 20:05:50 浏览: 168
if then else end if 是一种条件语句,用于在程序中根据条件执行不同的代码块。如果条件为真,则执行 if 后面的代码块;如果条件为假,则执行 else 后面的代码块。最后,无论条件是否为真,都会执行 end if 后面的代码块。
相关问题
oracle 中 if then else if else
在Oracle中,可以使用IF-THEN-ELSE语句来实现条件判断和分支控制。IF-THEN-ELSE语句用于根据条件的真假执行不同的代码块。
语法格式如下:
```
IF condition THEN
statement1;
ELSE IF condition THEN
statement2;
ELSE IF condition THEN
statement3;
...
ELSE
statementN;
END IF;
```
其中,condition是一个条件表达式,可以是任何返回布尔值的表达式。如果condition为真,则执行对应的statement;如果condition为假,则继续判断下一个条件,直到找到满足条件的分支或者执行ELSE部分的代码。
以下是一个示例:
```
DECLARE
num NUMBER := 10;
BEGIN
IF num > 0 THEN
DBMS_OUTPUT.PUT_LINE('Number is positive');
ELSE IF num < 0 THEN
DBMS_OUTPUT.PUT_LINE('Number is negative');
ELSE
DBMS_OUTPUT.PUT_LINE('Number is zero');
END IF;
END;
```
上述示例中,如果num大于0,则输出"Number is positive";如果num小于0,则输出"Number is negative";如果num等于0,则输出"Number is zero"。
Dim arrStim(140), Typecount(3),arrtmp(28) As Integer Dim i, k, flag As Integer Dim bools As Boolean For i = 1 To UBound(arrtmp) If i<21 Then k=1 arrtmp(i)=k Else If i<25 Then k=2 arrtmp(i)=k Else k=3 arrtmp(i)=k End If End If Next For i=1 To 5 Do bools=True RandomizeArray arrtmp,1,UBound(arrtmp) If i<>1 And i<>5 Then If arrtmp(1)=2 Or arrtmp(1)=3 Then If arrtmp(1)=flag Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If ElseIf i=1 Then If arrtmp(1)=2 Or arrtmp(1)=3 Or arrtmp(2)=2 Or arrtmp(2)=3 Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If ElseIf i=5 Then If arrtmp(27)=2 Or arrtmp(27)=3 Or arrtmp(28)=2 Or arrtmp(28)=3 Then bools=False ElseIf arrtmp(1)=2 Or arrtmp(1)=3 Then If arrtmp(1)=flag Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If End If Loop Until bools=True For k=1 To 28 arrStim((i-1)*28+k)=arrtmp(k) Next flag=arrtmp(28) Next For i=1 To UBound(arrStim) TrialList.SetNested CStr(i), "list" & arrStim(i) Next TrialList.Reset 要求:有三种实验材料,A材料100个、BC材料各20个。BC不能呈现在首尾的前后两个刺激上。BC同种材料不能重复呈现,BC可以挨着呈现。对A材料不反应,反应位错;对B材料按“f”键进行反应,C材料按“j”键进行反应。实验过程为:注视点800毫秒→刺激界面(无限时间) →反馈界面。设计要求: 1)请用“化整为零+随机打乱判断”法进行设计。 对以上编码进行修改
以下是修改后的代码:
Dim arrStim(140), Typecount(3), arrtmp(28) As Integer
Dim i, k, flag As Integer
Dim bools As Boolean
'设置实验材料
Typecount(1) = 100 'A材料100个
Typecount(2) = 20 'B材料20个
Typecount(3) = 20 'C材料20个
'生成随机序列
For i = 1 To UBound(arrtmp)
If i <= Typecount(2) Then '前20个为B材料
arrtmp(i) = 2
ElseIf i > Typecount(2) And i <= Typecount(2) + Typecount(3) Then '21-40为C材料
arrtmp(i) = 3
Else '41-140为A材料
arrtmp(i) = 1
End If
Next
'打乱随机序列并判断
For i = 1 To 5
Do
bools = True
RandomizeArray arrtmp, 1, UBound(arrtmp)
If i <> 1 And i <> 5 Then '2-4行不能为B或C材料
If arrtmp(1) = 2 Or arrtmp(1) = 3 Then
If arrtmp(1) = flag Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
ElseIf i = 1 Then '第1行不能为B或C材料,第2行也不能为B或C材料
If arrtmp(1) = 2 Or arrtmp(1) = 3 Or arrtmp(2) = 2 Or arrtmp(2) = 3 Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
ElseIf i = 5 Then '第5行不能为B或C材料,倒数第2行也不能为B或C材料
If arrtmp(27) = 2 Or arrtmp(27) = 3 Or arrtmp(28) = 2 Or arrtmp(28) = 3 Then
bools = False
ElseIf arrtmp(1) = 2 Or arrtmp(1) = 3 Then '第1个刺激不能为B或C材料
If arrtmp(1) = flag Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
End If
Loop Until bools = True
'将随机序列添加到实验材料列表中
For k = 1 To 28
arrStim((i - 1) * 28 + k) = arrtmp(k)
Next
flag = arrtmp(28) '记录上一行最后一个刺激的材料类型
Next
'将实验材料添加到TrialList中
For i = 1 To UBound(arrStim)
TrialList.SetNested CStr(i), "list" & arrStim(i)
Next
TrialList.Reset
阅读全文
相关推荐













