C:while中的把“==”写成“=”

while中的把“==”写成“=”

      通过做题,会发现易错的就是:容易把“==”写成“=”。在while 语句中,更容易发生这样的动作。接下来分析各种情况。

问题:下面的代码循环体执行几次?

(1)代码一如下:

#include <stdio.h>
int main()
{
	int i=1;
	while (i=0)
	{
		i++;
	}
	printf("%d\n",i);
	return 0;
}

         代码一的循环体执行次数:0 次。

         结果会打印 0 ,是因为 while 后的(i=0)为赋值语句,则现在语句为假,所以不进循环,并且 i 被赋值为 0。

 编译结果如下:

                                            

 (2)代码二如下:

#include <stdio.h>
int main()
{
	int i=0;
	while (i=1)
	{
		i++;
	}
	printf("%d\n",i);
	return 0;
}

        代码二的循环体执行次数:无限次。 

        编译结果是,光标一直在跳动,说明程序进入了死循环。原因:while 后面的(i=1)为赋值语句,则现在语句为真,所以一直进入循环,然后一直判断语句(i=1),所以形成了死循环。 

 编译结果如下: 

                                         

(3)代码三如下:

#include <stdio.h>
int main()
{
	int i=1;
	while (i==1)
	{
		i++;
	}
	printf("%d\n",i);
	return 0;
}

      代码三的循环体执行次数:1 次。 

       编译结果是 2 ,由于while后面的(i==1)为判断 i 的值是否为0 ,通过判断,(i == 1)为真,则进入循环,执行了  i++,则 i 的值变为 2 。

 编译结果如下: 

                                         

       总结:写“==”时特别注意,并检查,防止将赋值符号(==)误用为判断符号(=),可以养成习惯,将(i == 1)写为(1 == i),这样的话,若误写成(1 = i),一般的编译器会报错。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是我的代码:import sqlite3 conn = sqlite3.connect('C:\\Users\\Dell\\Desktop\\studentsTXL.db') conn.execute('create table if not exists students (stunum primary key,name,number)') #conn.execute('CREATE TABLE students(stunum INT PRIMARY KEY NOT NULL,name TEXT NOT NULL,number INT NOT NULL);') def add_student(): student_number = int(input('请输入学生学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"insert into sudents (stunum,name,number) values ({student_number},'{name}',{number})") conn.commit() print('学生信息添加成功') def delete_student(): student_number= int(input('请输入要删除的学生学号:')) conn.execute(f"delete from students where stunum={student_number}") conn.commit() print('学生信息删除成功') def modify_student(): student_number = int(input('请输入要修改的学生的学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"update students set name='{name}', number={number} where stunum={student_number}") conn.commit() print('学生信息修改成功') # 查询学生信息 def query_student(): student_number = int(input('请输入要查询的学生学号:')) cursor = conn.execute(f"select * from students where stunum={student_number}") row = cursor.fetchone() if row is None: print('无学生信息') else: print(f'学生学号:{row[0]},姓名:{row[1]},电话:{row[2]}') # 主程序 while True: print('这是学生信息管理系统') print('1. 添加学生信息') print('2. 删除学生信息') print('3. 修改学生信息') print('4. 查询学生信息') print('5. 退出系统') choice = int(input('请选择要执行的操作:')) if choice == 1: add_student() elif choice == 2: delete_student() elif choice == 3: modify_student() elif choice == 4: query_student() elif choice == 5: break else: print('无此项选择') conn.close(),在运行且输入学生信息后,查询显示无学生信息,请问如何改正
最新发布
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值