1215C++草稿

mulMatrix

void MatrixM(double A[][M],double B[][N]){
	double res[L][N]={0};//res[L][N]={1}会导致计算结果出错;
	int l,n,m;
	//没有必要double sum=0;直接将计算结果+=到res[l][n]即可
	for(l=0;l<L;l++){//A第一行
		for(n=0;n<N;n++){//B第一列
			for(m=0;m<M;m++)//第m个元素
				res[l][n]+=A[l][m]*B[m][n];//sum+=A[i][k]*B[k][i];//l=0表示第1行
            //容易写成res[l][m]
		}
	}
	for(l=0;l<L;l++){
		for(n=0;n<N;n++)
			cout<<res[l][n]<<" ";
		cout<<endl;  
	}
}

字符串

宏定义不是C语句,不必在行末加分号。如果加了分号则会连分号一起进行替换

二分法

for(int i=low;i<middle)
		if(searchKey==s[i])
			return i;//错误想法 这样和遍历每个数相差无几
void binarySearch(int s[],int searchKey,int size){
	int low=0,high=size-1;//将middle=(size-1)/2;写在这里会出现死循环
	while(low<high){
		int middle=(high+low)/2;
		cout<<"middle="<<middle<<"\tlow="<<low<<"\thigh="<<high<<endl;
		if(searchKey==s[middle]){
			cout<<middle<<endl;
			break;//确保此处也是while的一个出口
		}
		else if(searchKey<s[middle])
			high=middle-1;//high=middle牺牲效率了
			//return 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值