前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >条件运算符用法「建议收藏」

条件运算符用法「建议收藏」

作者头像
全栈程序员站长
发布2022-11-11 14:47:36
4150
发布2022-11-11 14:47:36
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

别人的书上看到一个简单题目,刚开始学C的小伙伴们应该很熟悉,还记得当年在软件实验室那会儿,入学考试全是这个,做到吐。

打印图形以下图形: * *** ***** ******* ********* *********** ************* *********** ********* ******* ***** *** *

一般方法:两重循环,里面是两个,上面三角形一个循环,倒三角一个循环。

代码语言:javascript
复制
for(int i=1;i<=13;i++)
	{
		if(i<=7)
		{
			for(int j=1;j<=2*i-1;j++)
			{
				cout<<"*";
			}
		}
		else
		{
			for(int j=1;j<=2*(7-(i-7))-1;j++)
			{
				cout<<"*";
			}
		}
		cout<<endl;
	}

我的方法,利用三目运算符将条件内置,因为两个循环只有中间的循环条件不一样,所以方便内置,复杂度也会相对低不少。

数大的话节省时间很有用的

代码语言:javascript
复制
for(int i=1;i<=13;i++)
	{
		for(int j=1;i<=7?j<=2*i-1:j<=2*(7-(i-7))-1;j++)
		{
			cout<<"*";
		}
		cout<<endl;
	}

条件运算符也就是 a>0 ? x : y, a>0是它的前置条件,当满足a>0时,执行X代表的式子或者计算X的值,不满足执行Y。

它其实就是IF语句的简化,

代码语言:javascript
复制
if(a>0)
{
    return x;
}
else
    return y;

当然例子还有很多,比如常用的GCD(最大公约数)算法,就可以用这个简化,看起来就比舒服。

代码语言:javascript
复制
int gcd(int a,int b){
        return b == 0 ? a:gcd(b,a%b);
     }

先就这么多吧,最后一年加油。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/186816.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月2日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档