|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
代码:
- //
- #include<stdio.h>
- int main()
- {
- int citysum,roadsum;
- int a,b,c;
- scanf("%d %d",&citysum,&roadsum);
- int map[citysum][citysum]; //这行出错
- for(int i=0;i<=citysum;i++)
- for(int j=0;j<=citysum;j++)
- map[i][j]=0;
-
- for(int i=0;i<roadsum;i++){
- scanf("%d %d %d",&a,&b,&c);
- map[a][b] = c;
- }
- for(int i=0;i<=citysum;i++){
- for(int j=0;j<=citysum;j++)
- printf("%d\t",map[i][j]);
- printf("\n");
- }
- return 0;
- }
复制代码
报错:
[b]- 错误 2 error C2057: 应输入常量表达式 11行
- 错误 3 error C2466: 不能分配常量大小为 0 的数组 11行
- 错误 4 error C2057: 应输入常量表达式 11行
- 错误 5 error C2466: 不能分配常量大小为 0 的数组 11行
- 错误 6 error C2087: “map”: 缺少下标 11行
- 错误 7 error C2133: “map”: 未知的大小 11行
复制代码 [b]
本帖最后由 永恒的蓝色梦想 于 2020-7-26 21:20 编辑
微软系的都不支持变长数组,而且你的程序可能下标越界。改为: - #include<stdio.h>
- #include<stdlib.h>
- #include<malloc.h>
- int main()
- {
- int citysum, roadsum;
- int a, b, c;
- scanf("%d %d", &citysum, &roadsum);
- int** map = (int**)malloc(citysum * citysum * sizeof(int));
- for (int i = 0; i < citysum; i++)
- for (int j = 0; j < citysum; j++)
- map[i][j] = 0;
- for (int i = 0; i < roadsum; i++) {
- scanf("%d %d %d", &a, &b, &c);
- map[a][b] = c;
- }
- for (int i = 0; i < citysum; i++) {
- for (int j = 0; j < citysum; j++)
- printf("%d\t", map[i][j]);
- printf("\n");
- }
- return 0;
- }
复制代码就可以了。
优化版: - #include<stdio.h>
- #include<stdlib.h>
- #include<malloc.h>
- #include<string.h>
- int main()
- {
- int citysum, roadsum;
- int a, b, c;
- scanf("%d%d", &citysum, &roadsum);
- int** map = (int**)malloc(citysum * citysum * sizeof(int));
- memset(map, 0, citysum * citysum * sizeof(int));
- for (int i = 0; i < roadsum; i++) {
- scanf("%d%d%d", &a, &b, &c);
- map[a][b] = c;
- }
- for (int i = 0; i < citysum; i++) {
- for (int j = 0; j < citysum; j++) {
- printf("%d\t", map[i][j]);
- }
- putchar('\n');
- }
- return 0;
- }
复制代码
还可以使用 calloc: - #include<stdio.h>
- #include<stdlib.h>
- #include<malloc.h>
- #include<string.h>
- int main()
- {
- int citysum, roadsum;
- int a, b, c;
- scanf("%d%d", &citysum, &roadsum);
- int** map = (int**)calloc(citysum * citysum, sizeof(int));
- for (int i = 0; i < roadsum; i++) {
- scanf("%d%d%d", &a, &b, &c);
- map[a][b] = c;
- }
- for (int i = 0; i < citysum; i++) {
- for (int j = 0; j < citysum; j++) {
- printf("%d\t", map[i][j]);
- }
- putchar('\n');
- }
- return 0;
- }
复制代码
|
|