Uva 422 - Word-Search Wonder

本文介绍了一个用于二维字符矩阵中搜索特定字符串的算法实现。通过遍历矩阵并利用方向判断,可以定位目标字符串的起始和结束位置。文章还涉及字符串处理技巧,如大小写转换,以增强匹配的灵活性。

之前有一道where is walf.....的题目

改改就好

1Y

#include<stdio.h>
#include<string.h>
char map[160][160];
int n,m;
int gl_x,gl_y,f_x,f_y;
bool f(int p,int q){
	if(p<0||q<0)return 1;
	if(p>=n||q>=m)return 1;
	return 0;
	}
int line(char *s,int p,int q,int x,int y){
	int len=strlen(s);
	int k;
	for(k=1;k<len;k++){
		p+=x;q+=y;
		if(f(p,q)||map[p][q]!=s[k])return 0;
		}
	return 1;
	}
bool Here(char *s,int p,int q){
	if(map[p][q]!=s[0])return 0;
	int i,j;
	int len=strlen(s);
	for(i=-1;i<=1;i++)for(j=-1;j<=1;j++){
		if(i==0&&j==0)continue;
	//	printf("%s~(%d,%d)+(%d,%d)=%d\n",s,p,q,i,j,line(s,p,q,i,j));
		if(line(s,p,q,i,j)){f_x=p+(len-1)*i;f_y=q+(len-1)*j;return 1;}
		}
	return 0;
	}
void search(char *s){
	int p,q;
	for(p=0;p<n;p++)for(q=0;q<m;q++){
		if(Here(s,p,q)){
			gl_x=p+1;
			gl_y=q+1;
			return;
			}
		}
	}
int main(){
	while(scanf("%d",&n)!=EOF&&n){
		m=n;
		int i,j;
		for(i=0;i<n;i++)scanf("%s",map[i]);
		for(i=0;i<n;i++)for(j=0;j<m;j++){
			char c=map[i][j];
			if(c>='A'&&c<='Z'){
				map[i][j]=c-'A'+'a';
				}
			}
		//	printf("!\n");
		char aim[160];
		int px,py;
		while(scanf("%s",aim)!=EOF){
			if(aim[0]=='0')break;
			gl_x=-1;
			for(i=0;i<strlen(aim);i++){
				char c=aim[i];
				if(c>='A'&&c<='Z'){
					aim[i]=c-'A'+'a';
					}
				}
			search(aim);
			if(gl_x!=-1)printf("%d,%d %d,%d\n",gl_x,gl_y,f_x+1,f_y+1);
			else printf("Not found\n");
			}
		}
	return 0;
	}


基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)内容概要:本文主要介绍基于NSGA-III算法求解微电网多目标优化调度的研究,并提供了完整的Matlab代码实现。研究聚焦于微电网系统中多个相互冲突的目标(如运行成本最小化、碳排放最低、可再生能源利用率最大化等)之间的权衡优化问题,采用NSGA-III(非支配排序遗传算法III)这一先进的多目标进化算法进行求解。文中详细阐述了微电网的数学模型构建、多目标优化问题的定义、NSGA-III算法的核心机制及其在该问题上的具体应用流程,并通过仿真案例验证了算法的有效性和优越性。此外,文档还提及该资源属于一个更广泛的MATLAB仿真辅导服务体系,涵盖智能优化、机器学习、电力系统等多个科研领域。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及工程技术人员。; 使用场景及目标:①学习和掌握NSGA-III等先进多目标优化算法的原理与实现;②研究微电网能量管理、多目标优化调度策略;③获取可用于科研或课程设计的Matlab代码参考,快速搭建仿真模型。; 阅读建议:此资源以算法实现为核心,建议读者在学习时结合代码与理论背景,深入理解目标函数的设计、约束条件的处理以及NSGA-III算法参数的设置。同时,可利用文中提供的网盘链接获取更多相关资源,进行横向对比和扩展研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值